這篇文章主要介紹了正則表達(dá)式的模式有哪些,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于網(wǎng)站設(shè)計、成都網(wǎng)站設(shè)計、馬龍網(wǎng)絡(luò)推廣、小程序制作、馬龍網(wǎng)絡(luò)營銷、馬龍企業(yè)策劃、馬龍品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎;創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供馬龍建站搭建服務(wù),24小時服務(wù)熱線:18982081108,官方網(wǎng)址:www.cdcxhl.com
正則表達(dá)式三種模式:貪婪模式、懶惰模式、獨占模式。
最后大家總結(jié)出了一個表格,如下所示:
根據(jù)這個表格,我們就能夠判斷出你寫的正則表達(dá)式效率到底高不高。這樣一來貪婪模式、懶惰模式、獨占模式就非常的好判斷了。
另外,通過官方文檔對比我們可以看出規(guī)律:
貪婪模式即在X字符后面增加限定符號如:?、*、+、{n}、{n,}、{n,m}
懶惰模式是在帶有限定符號:?、*、+、{n}、{n,}、{n,m}的后面,增加”?”,如:X??
獨占模式也叫侵占模式,是在帶有限定符號:?、*、+、{n}、{n,}、{n,m}的后面,增加”+”,如:X?+
下面看一個貪婪模式的例子:
Reluctant 懶惰模式,demo 如下:
Possessive 獨占模式。
3個模式的代碼雖然很簡單,但是,群里又有“懶貨“提出了新要求了。能不能寫一個工具來分析。這樣我就不用死記硬背了。
這個想法很好。而且,根據(jù)我們上面的表格,你都可以自己手動寫一個正則回溯分析工具了。原理很簡單,你就對正則表達(dá)式判斷是否獨占、懶惰、貪婪的特征。如果存在其中的一個特征,就是這個特征的所在的模式了。
根據(jù)這個思路,我相信你是可以寫出這樣的程序的。當(dāng)然,如果不會也沒關(guān)系。我給你推薦一個工具,regexbuddy。這個工具長的是下面這樣:
該工具支持多種程序語言正則表達(dá)式,如:perl,pcre,javascript,python,ruby,c#,java等等,還能自動生成程序代碼,并且內(nèi)部帶有大量的常用正則表達(dá)式。
用起來很簡單,也很爽,一直用一直爽!
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“正則表達(dá)式的模式有哪些”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!