詳解正則表達(dá)式的貪婪模式與非貪婪模式
什么是正則表達(dá)式的貪婪與非貪婪匹配
如:String str="abcaxc";
Patter p="ab*c";
貪婪匹配:正則表達(dá)式一般趨向于最大長(zhǎng)度匹配,也就是所謂的貪婪匹配。如上面使用模式p匹配字符串str,結(jié)果就是匹配到:abcaxc(ab*c)。
非貪婪匹配:就是匹配到結(jié)果就好,就少的匹配字符。如上面使用模式p匹配字符串str,結(jié)果就是匹配到:abc(ab*c)。
下面通過(guò)實(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")
貪婪模式就是“.+”中的+會(huì)一直查找到最后一個(gè)符合條件的字符,所以上述代碼中最前面的兩個(gè)數(shù)字在提取數(shù)字是沒(mé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 ","234-235-22-4223")
非貪婪模式就是在“.+?"會(huì)匹配到第一個(gè)符合條件的字符就停止
總結(jié)
以上所述是小編給大家介紹的正則表達(dá)式的貪婪模式與非貪婪模式,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!
相關(guān)文章
JavaScript正則表達(dá)式驗(yàn)證身份證號(hào)碼是否合法(兩種方法)
正則表達(dá)式(regular expression)是一個(gè)描述字符模式的對(duì)象。下面通過(guò)本篇文章給大家介紹js正則表達(dá)式驗(yàn)證身份證號(hào)碼是否合法,需要的朋友可以參考下本篇文章2015-09-09
JavaScript正則方法replace實(shí)現(xiàn)搜索關(guān)鍵字高亮顯示
這里介紹的是JavaScript的正則表達(dá)式的replace方法 ,和實(shí)現(xiàn)搜索關(guān)鍵字高亮的功能.先介紹一下正則表達(dá)式的replace方法,具體內(nèi)容詳情大家參考下本文2017-09-09
Javascript中正則表達(dá)式的使用及基本語(yǔ)法
正則表達(dá)式(Regular Expression)是一門簡(jiǎn)單語(yǔ)言的語(yǔ)法規(guī)范,是強(qiáng)大、便捷、高效的文本處理工具,它應(yīng)用在一些方法中,對(duì)字符串中的信息實(shí)現(xiàn)查找、替換和提取操作2017-10-10
php正則之函數(shù) preg_replace()參數(shù)說(shuō)明
php正則之函數(shù) preg_replace()參數(shù)說(shuō)明...2007-03-03

