您好,登錄后才能下訂單哦!
本篇內容主要講解“Python怎么定義實現最短匹配的正則表達式”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Python怎么定義實現最短匹配的正則表達式”吧!
1、需求
我們正在嘗試用正則表達式對文本模式做匹配,但識別出來的是最長的可能匹配。相反,我們想將其修改為最短的可能匹配。
2、解決方案
這個問題通常會在匹配的文本被一對開始和結束的分隔符包起來的時候出現(例如帶引號的字符串),為了說明這個問題,請看下面實例:
import re str_pat=re.compile(r'\"(.*)\"') text1='mark say "love"' text2='mark say "love",jingjing say "yes"' print(str_pat.findall(text1)) print(str_pat.findall(text2))
結果:
['love'] ['love",jingjing say "yes']
在這個例子中,模式r’"(.*)"'嘗試去匹配包含在引號中的文本。但是,*操作符在正則表達式中采用的是貪心策略,所以匹配過程是基于找出最長的可能匹配來進行的。所以上面才會出現【love",jingjing say "yes】這個匹配結果。
要解決這個問題,只要在模式中的*操作符后面加上?修飾符就可以了。
示例:
import re str_pat=re.compile(r'\"(.*?)\"') text1='mark say "love"' text2='mark say "love",jingjing say "yes"' print(str_pat.findall(text1)) print(str_pat.findall(text2))
結果:
['love']
['love', 'yes']
這么做使得匹配過程不會以貪心方式進行,也就會產生最短的匹配了。
到此,相信大家對“Python怎么定義實現最短匹配的正則表達式”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。