首頁  >  文章  >  後端開發  >  正規表示式惰性匹配模式(?)

正規表示式惰性匹配模式(?)

高洛峰
高洛峰原創
2017-01-09 16:23:062151瀏覽

正規表示式惰性匹配模式:
在貪婪匹配模式一章節已經說過人性是貪婪的,希望獲得更多的金錢、地位甚至美女,但是也有很多清心寡欲的人,只要滿足基本的生活需求就可以了,在正規表示式中也有這樣的配對原則,以下就來介紹。

一.惰性模式的概念:

此模式和貪婪模式恰好相反,它盡可能少的匹配字符以滿足正則表達式即可,例如:

var str="axxyyzbdkb";
console.log(str.match(/a.*b/));

   

能夠匹配整個字串,下面將其修改成惰性匹配模式:

var str="axxyyzbdkb";
console.log(str.match(/a.*?b/));

   

上面的程式碼即是惰性匹配,方法就是在重複量詞後面加上一個問號(?)即可。
惰性匹配模式是盡可能少的匹配字符,但是必須要滿足正則表達式的匹配規則,例如上面的代碼,*可以重複匹配0個或者多個前面的字符或者子表達式,但是正則表達式的結尾必須是b,所以正規表示式可以符合上面字串中的axxyyzb。

總結如下:

1.在重複量詞後面加上問號(?)即可形成惰性匹配。
2.惰性匹配會盡可能少的匹配字符,但是必須要滿足整個匹配模式。

二.惰性限定符列表:

正規表示式惰性匹配模式(?)

接下來是本人的簡介

其實貪婪和惰性很容易理解,從字面意思我們就可以知道,所謂的"貪婪"的意思就是,如果符合要求就一直往後匹配,一直到無法匹配為止,這就是貪婪模式。所謂的惰性模式就是一旦配對到適當的就結束,不在繼續配對下去了,以下我介紹幾個例子來主要講述一下。

首先講述一下貪婪模式的標示符:+,? ,*,{n},{n,},{n,m}.惰性模式:+? ,? ? ,*? ? ,{n}?,{n,}?,{n,m}?;

例子一

var pattern=/8[a-zA-Z0-9]*7/;贪婪模式
var string="abc8defghij7klngon8qrstwxy7";

   

這時使用了貪婪模式*,表示8與8之間可有任意多個字母,那這個正則先匹配第一個8,如果匹配到了後,就無限制的匹配後面的內容,只要後面的內容都滿足[a-zA-Z0-9]就可以。一直匹配,匹配到不能再匹配為止,看緊接著後面的一個是不是7,如果不是那他就往前進一個(吐出一個看是不是7),如果不是再繼續吐直到吐出7為止,然後匹配到的就是這之間的內容。所以結果匹配到的內容就是整個字串。

var pattern=/8[a-zA-Z0-9]*?7/ig;惰性模式
var string="abc8defghij7klngon8qrstwxy7";

   

上面正則使用了惰性模式*?,此時匹配方式是這樣的,先匹配一個8,然後在往後匹配一個字符看是不是符合[a-zA-Z0-9],如果符合,再去看緊接著後面的一個字符是不是7,如果是7就結束,如果不是就再往後匹配一個字符,看是不是符合[a-zA-Z0-9],如果符合,就再看緊接著後面的一個字元是不是7,如果是7就結束,否則,按照上面的方式依次循環下去,指導符合為止。

(2).貪婪和惰性模式還可以用另一種方​​式來表達。

例子二

var test="<img  src="aaa/111.jpg"/ alt="正規表示式惰性匹配模式(?)" ><img  src="aaa/112.jpg"/ alt="正規表示式惰性匹配模式(?)" ><img  src="aaa/113.jpg"/ alt="正規表示式惰性匹配模式(?)" >";
var pattern=/<img  [^ alt="正規表示式惰性匹配模式(?)" >]*\/>/ig;

   

這樣也可以實現惰性模式,[^>]這個表示的就是在正規表示式惰性匹配模式(?)之間不能出現>,所以結果可以找尋每個正規表示式惰性匹配模式(?)標籤。

更多正規表示式惰性匹配模式(?)相關文章請關注PHP中文網!


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn