成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

正則表達(dá)式- 捕獲組

CntChen / 776人閱讀

摘要:閱讀此篇文章前需要具備以下知識(shí)正則表達(dá)式的基本語(yǔ)法捕獲組是正則表達(dá)式里比較常用,也是比較重要的概念,我個(gè)人覺(jué)得掌握這部分的知識(shí)是非常重要的。我們知道的方法經(jīng)常和正則表達(dá)式一起使用。

PS: 閱讀此篇文章前需要具備以下知識(shí):

正則表達(dá)式的基本語(yǔ)法

String?.prototype?.replace()

String?.prototype?.match()

捕獲組(capturing group)是正則表達(dá)式里比較常用,也是比較重要的概念,我個(gè)人覺(jué)得掌握這部分的知識(shí)是非常重要的。
這篇文章內(nèi)容不會(huì)很深入,但是盡量做到簡(jiǎn)單易懂又全面。接下來(lái)的內(nèi)容主要是圍繞以下7個(gè)點(diǎn):

1: () 捕獲組
2: (?:) non capturing group
3: (?=) positive lookahead
4: (?!) negative lookahead
5: (?<=) positive lookbehind
6: (?7: (?=), (?!), (?<=), (?

1: () 捕獲組

/go+/

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

/(go)+/

為了全局匹配以及不考慮大小寫(xiě),我們接下來(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ù)字),但是注意不能匹配到句子開(kāi)頭的數(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: (?
負(fù)向就是與正向相反,那么負(fù)向后顧型捕獲就是:

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

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

let str = "1 turkey costs $2";
console.log( str.match(/(?

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 = /(?<=($|£))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在$的前面。

PS:截止到目前為止(ES2015),JavaScript還不支持后顧型匹配,就是說(shuō)(?<=), (?

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/104000.html

相關(guān)文章

  • Python正則達(dá)式很難?一篇文章搞定他,不是我吹!

    摘要:正則表達(dá)式語(yǔ)法字符與字符類(lèi)特殊字符以上特殊字符要想使用字面值,必須使用進(jìn)行轉(zhuǎn)義字符類(lèi)包含在中的一個(gè)或者多個(gè)字符被稱(chēng)為字符類(lèi),字符類(lèi)在匹配時(shí)如果沒(méi)有指定量詞則只會(huì)匹配其中的一個(gè)。 1. 正則表達(dá)式語(yǔ)法 1.1 字符與字符類(lèi) 1 特殊字符:.^$?+*{}| 以上特殊字符要想使用字面值,必須使用進(jìn)行轉(zhuǎn)義 2 字符類(lèi) 1. 包含在[]中的一個(gè)或者多個(gè)字符被稱(chēng)為字符類(lèi),字符類(lèi)在匹配時(shí)如果沒(méi)有指...

    dcr309duan 評(píng)論0 收藏0
  • TRY REGEX:正則達(dá)式交互式入門(mén)教程 翻譯&解答

    摘要:寫(xiě)一個(gè)正則表達(dá)式來(lái)測(cè)試變量中是否包含字符串。用函數(shù)給出不使用字符,但和等價(jià)的正則表達(dá)式。第十四課標(biāo)志全局匹配標(biāo)志第二個(gè)常用的標(biāo)志是全局匹配標(biāo)志,用字母表示。寫(xiě)出一個(gè)正則表達(dá)式來(lái)檢驗(yàn)合法性。非捕獲組的主要用途是給一個(gè)組賦予量詞。 TRY REGEX 是一個(gè)交互式的正則表達(dá)式學(xué)習(xí)項(xiàng)目項(xiàng)目地址:https://github.com/callumacra...在線地址:http://tryre...

    李義 評(píng)論0 收藏0
  • java正則表式的使用

    摘要:直接使用正則表達(dá)式對(duì)輸入的字符串進(jìn)行匹配,匹配成功則返回使用正則表示式,進(jìn)行字符串分割進(jìn)行匹配操作,如果匹配成功,這三個(gè)方法都會(huì)返回其中,是在源字符串中找出和正則表達(dá)式匹配的字符串。 概念 正則表達(dá)式 在閱讀本文前,你應(yīng)該已經(jīng)了解了正則表達(dá)式的基本概念以及如何書(shū)寫(xiě)正則表達(dá)式。如果對(duì)正則表達(dá)式不是太了解,或者想更深入地了解正則表示式,請(qǐng)點(diǎn)擊這里。 捕獲組 捕獲組能夠讓我們方便地從正則表達(dá)...

    zoomdong 評(píng)論0 收藏0
  • 正則達(dá)式在 ES2018 中的新寫(xiě)法

    摘要:自從年推出標(biāo)準(zhǔn)第版以來(lái),正則表達(dá)式已成為語(yǔ)言的一部分。最后,如果在正則表達(dá)式中使用了命名捕獲組,則將它們放在屬性中。支持與相同語(yǔ)法的命名組已經(jīng)模仿了的正則表達(dá)式語(yǔ)法。下面是一個(gè)例子此正則表達(dá)式在句子中查找連續(xù)的重復(fù)單詞。 翻譯:瘋狂的技術(shù)宅原文:https://www.smashingmagazine.... 本文首發(fā)微信公眾號(hào):jingchengyideng歡迎關(guān)注,每天都給你推...

    lanffy 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<