為什么只能匹配出第一個(gè)符合條件的字符串?
import?re def?main(): str?=?'HELLO?hello' pa?=?re.compile(r'(hello)',re.I) p?=?pa.match(str) print(pa) print(p.groups()) main()
不應(yīng)該是兩個(gè)hello都匹配出來嗎?但是結(jié)果只有第一個(gè)小寫的
import?re def?main(): str?=?'HELLO?hello' pa?=?re.compile(r'(hello)',re.I) p?=?pa.match(str) print(pa) print(p.groups()) main()
不應(yīng)該是兩個(gè)hello都匹配出來嗎?但是結(jié)果只有第一個(gè)小寫的
2017-08-16
舉報(bào)
2020-11-21
match() 方法將檢索字符串 stringObject,以找到一個(gè)或多個(gè)與 regexp 匹配的文本。這個(gè)方法的行為在很大程度上有賴于 regexp 是否具有標(biāo)志 g。
如果 regexp 沒有標(biāo)志 g,那么 match() 方法就只能在 stringObject 中執(zhí)行一次匹配。如果沒有找到任何匹配的文本, match() 將返回 null。否則,它將返回一個(gè)數(shù)組,其中存放了與它找到的匹配文本有關(guān)的信息。該數(shù)組的第 0 個(gè)元素存放的是匹配文本,而其余的元素存放的是與正則表達(dá)式的子表達(dá)式匹配的文本。除了這些常規(guī)的數(shù)組元素之外,返回的數(shù)組還含有兩個(gè)對(duì)象屬性。index 屬性聲明的是匹配文本的起始字符在 stringObject 中的位置,input 屬性聲明的是對(duì) stringObject 的引用。
如果 regexp 具有標(biāo)志 g,則 match() 方法將執(zhí)行全局檢索,找到 stringObject 中的所有匹配子字符串。若沒有找到任何匹配的子串,則返回 null。如果找到了一個(gè)或多個(gè)匹配子串,則返回一個(gè)數(shù)組。不過全局匹配返回的數(shù)組的內(nèi)容與前者大不相同,它的數(shù)組元素中存放的是 stringObject 中所有的匹配子串,而且也沒有 index 屬性或 input 屬性。
摘自w3c教程
str 的值改成 /HELLO?hello/?
2019-09-18
match方法內(nèi)部定義的應(yīng)該就是從左往右,找到第一個(gè)匹配就結(jié)束;后面有一個(gè)findall方法可以找到所有匹配的字符串
2017-08-16
畢竟是match不是find函數(shù)
2017-08-16
這個(gè)方法內(nèi)部定義的應(yīng)該就是從左往右,找到第一個(gè)匹配就結(jié)束;后面有一個(gè)findall方法可以找到所有匹配的字符串
2017-08-16
你對(duì)概念有些混淆,正則表達(dá)式是為了判斷 一個(gè)字符串是否滿足一定的規(guī)則