說說 Python 的貪心和非貪心匹配策略

Python 的正則表達(dá)式默認(rèn)是“ 貪心” 匹配策略, 這表示在有二義的情況下,Python 會盡可能地匹配最長的字符串。而 “ 非貪心” 策略則是盡可能地匹配最短的字符串,它與“ 貪心” 匹配策略在寫法上的區(qū)別是:在結(jié)束的花括號后跟著一個問號。

greedy_regex=re.compile(r'(AR){1,2}')
mo=greedy_regex.search('家庭ARAR演唱會來Facebook Portal TV,一展歌喉!')
print(mo.group())

no_greedy_regex=re.compile(r'(AR){1,2}?')
mo=no_greedy_regex.search('家庭ARAR演唱會來Facebook Portal TV,一展歌喉!')
print(mo.group())

運(yùn)行結(jié)果:

ARAR
AR

注意區(qū)分: 問號在 Python 正則表達(dá)式中有兩種含義:

  • 聲明非貪心匹配。
  • 表示可選的分組。
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容