詳解正則表達(dá)式的貪婪模式與非貪婪模式
什么是正則表達(dá)式的貪婪與非貪婪匹配
如:String str="abcaxc";
Patter p="ab*c";
貪婪匹配:正則表達(dá)式一般趨向于最大長度匹配,也就是所謂的貪婪匹配。如上面使用模式p匹配字符串str,結(jié)果就是匹配到:abcaxc(ab*c)。
非貪婪匹配:就是匹配到結(jié)果就好,就少的匹配字符。如上面使用模式p匹配字符串str,結(jié)果就是匹配到:abc(ab*c)。
下面通過實(shí)例代碼看下正則表達(dá)式的貪婪模式與非貪婪模式,具體內(nèi)容如下所示:
貪婪模式:能匹配的最大部分
s = "This is a number 234-235-22-4223" r = re.match(r"(.+)(\d+-\d+-\d+-\d+",s) r.groups() ("This is a number 23","4-235-22-4223")
貪婪模式就是“.+”中的+會一直查找到最后一個符合條件的字符,所以上述代碼中最前面的兩個數(shù)字在提取數(shù)字是沒有被提取到
非貪婪模式:匹配越少越好
s = "This is a number 234-235-22-4223" r = re.match(r"(.+?)(\d+-\d+-\d+-\d+",s) r.groups() ("This is a number ","234-235-22-4223")
非貪婪模式就是在“.+?"會匹配到第一個符合條件的字符就停止
總結(jié)
以上所述是小編給大家介紹的正則表達(dá)式的貪婪模式與非貪婪模式,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復(fù)大家的!
相關(guān)文章
好東西,老外用正則表達(dá)式寫的HTML分離函數(shù)
好東西,老外用正則表達(dá)式寫的HTML分離函數(shù)...2006-06-06正則表達(dá)式實(shí)現(xiàn)最小匹配功能的方法
這篇文章主要介紹了正則表達(dá)式實(shí)現(xiàn)最小匹配功能的方法,結(jié)合具體實(shí)例形式分析了正則表達(dá)式最小匹配功能的原理與實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-02-02用正則表達(dá)式匹配字符串中漢字及中文標(biāo)點(diǎn)符號
正則表達(dá)式通常用于判斷某一個字符串是否符合或滿足某一種格式,下面這篇文章主要給大家介紹了關(guān)于如何使用正則表達(dá)式匹配字符串中漢字及中文標(biāo)點(diǎn)符號的相關(guān)資料,需要的朋友可以參考下2022-07-07判斷用戶輸入的銀行卡號是否正確的方法(基于Luhn算法的格式校驗(yàn))
下面小編就為大家?guī)硪黄袛嘤脩糨斎氲你y行卡號是否正確的方法(基于Luhn算法的格式校驗(yàn))。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04