溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

正則表達(dá)式中如何捕獲組

發(fā)布時(shí)間:2021-09-03 11:40:20 來(lái)源:億速云 閱讀:161 作者:小新 欄目:互聯(lián)網(wǎng)科技

小編給大家分享一下正則表達(dá)式中如何捕獲組,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

1: () 捕獲組

/go+/

以上的正則表達(dá)式表示一個(gè)字母g后面跟上一個(gè)或者多個(gè)字母o,他能匹配go或者goooo。但是如果我們想+不只是運(yùn)用到字母o上,而是運(yùn)用到go這個(gè)整體上怎么辦呢?辦法就是給go加括號(hào):

/(go)+/

為了全局匹配以及不考慮大小寫,我們接下來(lái)會(huì)給我們的正則加上ig,這兩個(gè)flag:

let reg = /(go)+/ig;
'go is g gogo'.match(reg); //["go", "gogo"]

在上面的例子里面(go)就形成了一個(gè)捕獲組(capturing group)。接下來(lái)看一個(gè)使用捕獲組的例子來(lái)加深對(duì)它的理解:

let reg = /(\d{2}).(\d{2}).(\d{4})/;
let originString = '10.25.2017';
reg.test(originString); //true
RegExp.$1; //10
RegExp.$2; //25
RegExp.$2; //2017

在上面這個(gè)例子里,我們有三組括號(hào),形成了三個(gè)捕獲組,正則表達(dá)式(在javaScript里就是我們的RegExp)會(huì)緩存捕獲組所匹配的串,以$n表示,n就代表這第幾個(gè)捕獲組。

假如現(xiàn)在我們有一個(gè)需求:把顯示格式為 10.25.2017 的時(shí)間改為 2017-10-25 格式。

我們知道String的replace()方法經(jīng)常和正則表達(dá)式一起使用。在replace()方法里,我們可以直接使用捕獲組的結(jié)果:

let reg = /(\d{2}).(\d{2}).(\d{4})/;
let originString = '10.25.2017';
let newString = originString.replace(reg, '$3-$1-$2');
console.log(newString);//"2017-10-25"

2: (?:) non capturing group 非捕獲型分組

有的時(shí)候我們可能只想匹配分組,但是并不想緩存(不想捕獲)匹配到的結(jié)果,就可以在我們的分組模式前面加上?:。例如上面的時(shí)間的例子,我們不想捕獲第一個(gè)分組的結(jié)果,就可以這么做:

let reg = /(?:\d{2}).(\d{2}).(\d{4})/;
let originString = '10.25.2017';
reg.test(originString); //true
RegExp.$1; //25
RegExp.$2; //2017
originString.match(reg);// ["10.25.2017", "25", "2017", index: 0, input: "10.25.2017", groups: undefined]

從上面的例子可以看出,我們的正則表達(dá)式依然是匹配的(test()的結(jié)果依然為true),但是RegExp.$1不是數(shù)字10,而是25,因?yàn)槲覀冊(cè)诘谝粋€(gè)括號(hào)里加了?:,10就不會(huì)被捕獲。match()的執(zhí)行結(jié)果也會(huì)受?:的影響:match()的結(jié)果里不再有‘10'。

3: (?=) positive lookahead 正向前瞻型捕獲

有一個(gè)句子:1 apple costs 10?. 我們想要匹配?前面的價(jià)格(這里是一個(gè)數(shù)字),但是注意不能匹配到句子開頭的數(shù)字1。這種情況,就可以用到正向前瞻型捕獲:

let reg = /\d+(?=?)/g;
let reg1 = /\d+/g;
let str = '1 apple costs 10?';
str.match(reg); //["10"]
str.match(reg1); //["1", "10"]

上面的例子里面reg1就只需要匹配數(shù)字,對(duì)于數(shù)字后面跟什么并沒(méi)有要求,所以它能匹配到1,10。但是reg使用了前瞻型匹配,就只能匹配到10。
或許你已經(jīng)能從上面的對(duì)比里了解到什么是正向前瞻型捕獲了,意思是:

/x(?=y)/ 匹配x, 但是必須在x的【后面】【是】y的情況下

4: (?!) negative lookahead 負(fù)向前瞻型捕獲

上面我們了解了什么是正向前瞻型匹配,從字面意思也能猜出來(lái)負(fù)向前瞻型捕獲就是:

/x(?!y)/ 匹配x, 但是必須在x的【后面】【不是】y的情況下

例如下面的例子,我們要匹配數(shù)字1,而不要?前面的2,就可以用到?!:

let reg = /\d+(?!?)/g;
let str = '1 apple costs 2?';
str.match(reg); ['1']

5: (?<=) positive lookbehind 正向后顧型捕獲

后顧型和前瞻型正好相反,意思就是:

/(?<=y)x/ 匹配x, 但是只在【前面】【有】y的情況下

來(lái)看一個(gè)例子:

let str = "1 turkey costs $2";
console.log( str.match(/(?<=\$)\d+/g) ); //["2"]

這里的要求是前面有$的數(shù)字,所以這里匹配到了數(shù)字2,而沒(méi)有1.

6: (?<!) negative lookbehind 負(fù)向后顧型捕獲

負(fù)向就是與正向相反,那么負(fù)向后顧型捕獲就是:

/(?<=y)x/ 匹配x, 但是只在【前面】【沒(méi)有】y的情況下

來(lái)看一個(gè)例子:

let str = "1 turkey costs $2";
console.log( str.match(/(?<!\$)\d+/g) ); //['1']

7: (?=), (?!), (?<=), (?<!)的捕獲

默認(rèn)情況下上面的前瞻后顧4種都是默認(rèn)不匹配捕獲組里面的內(nèi)容的,也就是不匹配括號(hào)里的條件的。例如我們的正向前瞻/d+(?=?)/g,只會(huì)匹配到數(shù)字,并不會(huì)匹配到?。如果我們想要也匹配到?怎么辦呢?答案就是給?也包上一個(gè)括號(hào):

let str = "1 turkey costs 2?";
let reg = /\d+(?=(?))/; 
str.match(reg); //["2", "?", index: 15, input: "1 turkey costs 2?", groups: undefined]

這樣就匹配到了數(shù)字2和它后面的?。

下面再來(lái)看看后顧型:

let str = "1 turkey costs $2";
let reg = /(?<=(\$|&pound;))\d+/;
console.log( str.match(reg) ); //["2", "$", index: 16, input: "1 turkey costs $2", groups: undefined]

需要特別注意到的一點(diǎn)是,對(duì)于后顧型,雖然條件在匹配項(xiàng)的前面,但是匹配出來(lái)的結(jié)果順序依然是條件在匹配項(xiàng)的后面。所以這里match()出來(lái)的結(jié)果是2在$的前面。

以上是“正則表達(dá)式中如何捕獲組”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI