婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 正則表達式惰性匹配模式(?)

正則表達式惰性匹配模式(?)

熱門標簽:地圖標注教學(xué)點 梅縣地圖標注 ai電話機器人搭建 貴港公司如何申請400電話 400電話辦理電話辦理 呼叫系統(tǒng)外呼只能兩次 外呼系統(tǒng)無呼出路由是什么原因 西藏智能外呼系統(tǒng)代理商 甘肅醫(yī)療外呼系統(tǒng)排名

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

一.惰性模式的概念:

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

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

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

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

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

總結(jié)如下:

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

二.惰性限定符列表:

語法結(jié)構(gòu) 語義解釋
*? 可以重復(fù)任意次,但是盡可能重復(fù)少的次數(shù)。
+? 可以重復(fù)1次或者任意多次,但是盡可能重復(fù)少的次數(shù),不過最少次數(shù)是1。
?? 可以重復(fù)0次或1次,但盡可能少重復(fù)。
{n,m}? 可以重復(fù)n到m此,但盡可能少重復(fù),最少匹配次數(shù)是n。
{n,}? 可以重復(fù)n次以上,但盡可能少重復(fù),最少匹配n此。

首先引入一個介紹比較詳細的網(wǎng)站

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

接下來是本人的簡介

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

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

例子一

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

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

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

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

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

例子二

var test="img src="aaa/111.jpg"/>img src="aaa/112.jpg"/>img src="aaa/113.jpg"/>";
var pattern=/img [^>]*\/>/ig;

這樣也可以實現(xiàn)惰性模式,[^>]這個表示的就是在img到/>之間不能出現(xiàn)>,所以結(jié)果可以找尋每個img>標簽。

您可能感興趣的文章:
  • 正則表達式中最短匹配模式的用法淺析
  • JS中正則表達式全局匹配模式 /g用法詳解
  • Java 正則表達式匹配模式(貪婪型、勉強型、占有型)
  • 正則表達式全局匹配模式(g修飾符)
  • 正則表達式常見的4種匹配模式小結(jié)

標簽:常州 泰安 海口 湖州 哈密 本溪 涼山 大興安嶺

巨人網(wǎng)絡(luò)通訊聲明:本文標題《正則表達式惰性匹配模式(?)》,本文關(guān)鍵詞  正則,表達式,惰性,匹配,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《正則表達式惰性匹配模式(?)》相關(guān)的同類信息!
  • 本頁收集關(guān)于正則表達式惰性匹配模式(?)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 萍乡市| 枣强县| 霍林郭勒市| 太仆寺旗| 东辽县| 南平市| 滕州市| 伊川县| 长治市| 镇原县| 施秉县| 金川县| 长春市| 许昌县| 武清区| 扎兰屯市| 大埔县| 岐山县| 兴义市| 临颍县| 石楼县| 鄂温| 定西市| 武汉市| 广灵县| 龙陵县| 阿拉善左旗| 策勒县| 新泰市| 延庆县| 洪江市| 淳化县| 扶余县| 日照市| 沈丘县| 云和县| 河曲县| 兴宁市| 黄山市| 辉南县| 平武县|