好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > Python re.sub 反向引用的實現

Python re.sub 反向引用的實現

熱門標簽:銀川電話機器人電話 預覽式外呼系統 煙臺電話外呼營銷系統 如何地圖標注公司 外賣地址有什么地圖標注 長春極信防封電銷卡批發 企業彩鈴地圖標注 電銷機器人錄音要學習什么 上海正規的外呼系統最新報價

re 模塊是 Python 標準庫中提供的用于處理正則表達式的模塊,利用 re 模塊可以方便的利用正則表達式實現字符串中的匹配、替換等操作

match 分組

Python re 模塊中提供了 match 函數,用來匹配字符串中指定的正則表達式規則。例如,如果想匹配到 "Isaac Newton, physicist" 中的 Isaac Newton,則可以使用正則表達式 \w+ \w+ ,運行結果如下:

>>> m = re.match("\w+ \w+", "Isaac Newton, physicist")
>>> m
re.Match object; span=(0, 12), match='Isaac Newton'>

re.match 的第一個參數是指定的正則表達式規則,第二個參數是待匹配的字符串。正則表達式規則 \w+ 表示匹配一段連續的字符,要求匹配到的字符數量大于 1。 \w+ \w+ 就表示匹配兩段連續的字符,且兩段字符中間用空格隔開

使用 match 執行匹配時會對匹配到的結果進行 分組 ,可以通過 match 返回結果的 group() 接口查看分組結果

>>> m.group(0)
'Isaac Newton'

默認情況下, match 只會產生一個分組,就是第 0 個分組,表示整個匹配到的內容。對于上面的例子,第 0 個分組就是 \w+ \w+ 匹配到的完整的內容,也就是 Issac Newton 。
使用正則表達式中的括號 () 可以手動指定匹配的分組。例如如果想把 Issac 和 Newton 做為兩個分組,那么可以將正則表達式改為 (\w+) (\w+) :

>>> m = re.match("(\w+) (\w+)", "Isaac Newton, physicist")

在 (\w+) (\w+) 這個正則表達式中,指定了兩個分組,這兩個分組匹配的內容都是 \w+ ,并且兩個分組之間用空格隔開。
使用 groups() 可以查看匹配結果中的所有分組 :

>>> m.groups()
('Isaac', 'Newton')

也可以使用 group() 接口分別查看每一個分組,其中 group(0) 仍然表示完整的匹配結果, group(1) 表示匹配結果中的第 1 個分組, group(2) 表示第 2 個分組,以此類推:

>>> m.group(0)
'Isaac Newton'
>>> m.group(1)
'Isaac'
>>> m.group(2)
'Newton'

re.sub 匹配和替換

re.match() 函數提供了正則表達式的匹配接口, re.sub() 不光能匹配正則表達式,還能替換字符串中的結果,生成一個新的字符串。
例如把字符串中 (\w+) (\w+) 匹配到的結果替換成 Albert Einstein ,可以這樣寫:

>>> re.sub("(\w+) (\w+)", "Albert Einstein", "Isaac Newton, physicist")
'Albert Einstein, physicist'

re.sub 中第 1 個參數表示匹配的正則表達式,第 2 個參數表示替換表達式,第 3 個參數表示原始字符串

這里的替換表達式是手動指定的新字符串 Albert Einstein ,他和原始字符串中的內容毫不相關。如果希望復用原始字符串中的內容,那么就需要用到 re.sub 的反向引用功能了。

反向引用

反向引用指的是在指定替換結果的過程中,可以引用原始字符串中的匹配到內容。例如 (\w+) (\w+) 在原始字符串中匹配到了 Isaac Newton ,利用匹配到的結果,將結果改寫為 FirstName: Isaac, LastName: Newton 。
既然需要引用,那么就得有一個表達式能夠表示匹配的內容。恰好 re.sub 的匹配結果也有和 re.match 一樣的分組,因此只需要在替換表達式中引用分組的結果即可。引用方式有以下幾種:

  • \number :例如 \1 ,表示匹配結果中第 1 個分組,也就是例子中的 Isaac 部分。
  • \gnumber> :例如 \g1> ,和 \number 表示法一樣,也代表了匹配結果中的第 1 個分組。與 \number 表示法相比, \gnumber> 避免了歧義。試想,如果想用 \number 把第 1 個分組匹配到的  Isaac 替換為 Isaac0 ,那么需要用 \10 ,這里本意表示在第 1 個分組后加上 0 ,但程序會識別成第 10 個分組。而使用 \gnumber> 只需要寫成 \g1>0 即可。

回到開始的例子中,將匹配結果 Isaac Newton改寫為 FirstName: Isaac, LastName: Newton ,可以用以下表達式實現:

>>> re.sub("(\w+) (\w+)", "FirstName: \g1>, LastName: \g2>", "Isaac Newton, physicist")
'FirstName: Isaac, LastName: Newton, physicist'

參考

 re — Regular expression operations
 Python re(gex)? -- Groupings and backreferences

到此這篇關于Python re.sub 反向引用的實現的文章就介紹到這了,更多相關Python re.sub 反向引用內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家! 

您可能感興趣的文章:
  • 用Python代碼自動生成文獻的IEEE引用格式的實現
  • 淺析Python模塊之間的相互引用問題
  • python3爬蟲中引用Queue的實例講解
  • python閉包與引用以及需要注意的陷阱
  • 詳解python如何引用包package
  • python 引用傳遞和值傳遞詳解(實參,形參)
  • Python參數傳遞機制傳值和傳引用原理詳解
  • Python參數傳遞對象的引用原理解析
  • python實現引用其他路徑包里面的模塊
  • python關于多級包之間的引用問題

標簽:宜昌 湖北 佳木斯 上饒 珠海 潮州 西寧 盤錦

巨人網絡通訊聲明:本文標題《Python re.sub 反向引用的實現》,本文關鍵詞  Python,re.sub,反向,引,用的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Python re.sub 反向引用的實現》相關的同類信息!
  • 本頁收集關于Python re.sub 反向引用的實現的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 差差软件app大全免费结治| 免费边摸边吃奶边叫床视频| 欧美AV无码成人精品区| 聊斋艳谭之性色生活| keez韩国护士| 又色又爽又黄的视频网站| 日本三级电影网址| www.????茄子.com| 国产精品白丝在线观看有码 | 日日摸夜夜爽夜夜爽无码精品| 好猛好紧好硬使劲好大刺激视频| 911色_911色sss在线观看| 成人男女网18免费0| 韩国青草视频19禁福利国青草直播| 韩国理伦三级做爰| 日韩在线电影| 日日爱夜夜爱| 日本亲子乱婬A片在线| 不卡的中文字幕| vodafone巨大黑| 小小水蜜桃3视频高清在线观看 | 免费人成黄页在线观看69| 日韩电影天堂| 国产精品喷潮抽搐无码动漫| 经典三级在线观看| 国产拍拍拍精品视频| 欧美午夜理伦三级在线观看吃奶汁| 91精品久久久老熟女九色91| 免费无遮挡网站| 英语老师解开胸罩喂我乳视频| 喜爱夜蒲1大尺度吃乳| 把英语课代表按在地上C| 成人三级在线播放线观看| 人色偷偷色AV噜噜狠狠99| 中国真人性做爰ⅩXX| 手机看片日韩高清国产欧美| 三个不道德的女人| 色窝窝无码一区二区三区在线观看| 亚洲精品久久久无码aⅴ片小岛南| 黄色网入口| 尹人香蕉久久99天天拍欧美p7|