亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

為什么只能匹配出第一個符合條件的字符串?

import?re
def?main():
	str?=?'HELLO?hello'
	pa?=?re.compile(r'(hello)',re.I)
	p?=?pa.match(str)
	print(pa)
	print(p.groups())

main()

不應該是兩個hello都匹配出來嗎?但是結果只有第一個小寫的

正在回答

5 回答

match() 方法將檢索字符串 stringObject,以找到一個或多個與 regexp 匹配的文本。這個方法的行為在很大程度上有賴于 regexp 是否具有標志 g。

如果 regexp 沒有標志 g,那么 match() 方法就只能在 stringObject 中執行一次匹配。如果沒有找到任何匹配的文本, match() 將返回 null。否則,它將返回一個數組,其中存放了與它找到的匹配文本有關的信息。該數組的第 0 個元素存放的是匹配文本,而其余的元素存放的是與正則表達式的子表達式匹配的文本。除了這些常規的數組元素之外,返回的數組還含有兩個對象屬性。index 屬性聲明的是匹配文本的起始字符在 stringObject 中的位置,input 屬性聲明的是對 stringObject 的引用。

如果 regexp 具有標志 g,則 match() 方法將執行全局檢索,找到 stringObject 中的所有匹配子字符串。若沒有找到任何匹配的子串,則返回 null。如果找到了一個或多個匹配子串,則返回一個數組。不過全局匹配返回的數組的內容與前者大不相同,它的數組元素中存放的是 stringObject 中所有的匹配子串,而且也沒有 index 屬性或 input 屬性。

摘自w3c教程

str 的值改成 /HELLO?hello/?

0 回復 有任何疑惑可以回復我~

match方法內部定義的應該就是從左往右,找到第一個匹配就結束;后面有一個findall方法可以找到所有匹配的字符串

0 回復 有任何疑惑可以回復我~

畢竟是match不是find函數

0 回復 有任何疑惑可以回復我~

這個方法內部定義的應該就是從左往右,找到第一個匹配就結束;后面有一個findall方法可以找到所有匹配的字符串

2 回復 有任何疑惑可以回復我~

你對概念有些混淆,正則表達式是為了判斷 一個字符串是否滿足一定的規則

1 回復 有任何疑惑可以回復我~
#1

慕俠1411466 提問者

不是篩選出符合規則的部分嗎
2017-08-16 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消

為什么只能匹配出第一個符合條件的字符串?

我要回答 關注問題
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號