首頁  >  文章  >  web前端  >  正規的惰性匹配模式(?)使用詳解

正規的惰性匹配模式(?)使用詳解

php中世界最好的语言
php中世界最好的语言原創
2018-03-30 11:34:391814瀏覽

這次帶給大家正規的惰性匹配模式(?)使用詳解,正規惰性匹配模式(?)使用的注意事項有哪些,以下就是實戰案例,一起來看一下。

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

一.惰性模式的概念:

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

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

以上程式碼是貪婪模式,於是能夠匹配整個字串,以下將其修改成惰性匹配模式:

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

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

總結如下:

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

二.惰性限定符列表:

#語法結構 語意解釋
*? 可以重複任意次,但盡可能重複少的次數。
+? 可以重複1次或任意多次,但是盡可能重複少的次數,不過最少次數是1。
?? 可以重複0次或1次,但盡可能少重複。
{n,m}? 可以重複n到m此,但盡可能少重複,最少符合次數是n。
{n,}? 可以重複n次以上,但盡可能少重複,最少符合n此。

首先引入一个介绍比较详细的网站

http://www.jb51.net/article/31491.htm

接下来是本人的简介

其实贪婪和惰性很容易理解,从字面意思我们就可以知道,所谓的"贪婪"的意思就是,如果符合要求就一直往后匹配,一直到无法匹配为止,这就是贪婪模式。所谓的惰性模式就是一旦匹配到合适的就结束,不在继续匹配下去了,下面我介绍几个例子来主要讲述一下。

首先讲述一下贪婪模式的标示符:+,?,*,{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"/><img src="aaa/112.jpg"/><img src="aaa/113.jpg"/>";
var pattern=/<img [^>]*\/>/ig;

这样也可以实现惰性模式,[^>]这个表示的就是在之间不能出现>,所以结果可以找寻每个标签。

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

js里的正则实现数字每隔四位用空格分隔效果

在PHP里使用正则的效率 贪婪、非贪婪与回溯详解(附代码)

以上是正規的惰性匹配模式(?)使用詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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