黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

Python妙用re.sub分析正則表達(dá)式匹配過(guò)程

系統(tǒng) 2087 0

聲明:本文所使用方法為老猿自行研究并編碼,相關(guān)代碼版權(quán)為老猿所有,禁止轉(zhuǎn)載文章,代碼禁止用于商業(yè)用途!

在《第11.23節(jié) Python 中re模塊的搜索替換功能:sub及subn函數(shù)》介紹了re.sub函數(shù),其中的替換內(nèi)容可以是一個(gè)函數(shù),利用該功能我們可以展示正則表達(dá)式匹配過(guò)程中匹配到的目標(biāo)子串的匹配順序、匹配文本的內(nèi)容和匹配文本在搜索文本中的位置。具體實(shí)現(xiàn)如下:

            
              import re
matchcount = 0

def parsematch(patstr,text):
    global matchcount
    matchcount = 0
    re.sub(patstr,matchrsult,text)
    
def matchrsult(m):
    global matchcount
    matchcount += 1   
    print(f"第{matchcount}次匹配,匹配情況:")
    if(m.lastindex):
        for i in range(0,m.lastindex+1):print(f"    匹配子串group({i}): {m.group(i)},位置為:{m.span(i)}") #正則表達(dá)式為{m.re},搜索文本為{m.string},
    else:print(f"    匹配子串group(0): {m.group(0)},位置為:{m.span(0)}")
    return m.group(0)

            
          

調(diào)用舉例:

            
              >>> parsematch(r'(?i)(?P
              
                py\w*)','Python?PYTHON!Learning python with LaoYuan! ')
第1次匹配,匹配情況:
    匹配子串group(0): Python,位置為:(0, 6)
    匹配子串group(1): Python,位置為:(0, 6)
第2次匹配,匹配情況:
    匹配子串group(0): PYTHON,位置為:(7, 13)
    匹配子串group(1): PYTHON,位置為:(7, 13)
第3次匹配,匹配情況:
    匹配子串group(0): python,位置為:(23, 29)
    匹配子串group(1): python,位置為:(23, 29)
>>>
>>> parsematch('(.?)*',"abc")
第1次匹配,匹配情況:
    匹配子串group(0): abc,位置為:(0, 3)
    匹配子串group(1): ,位置為:(3, 3)
第2次匹配,匹配情況:
    匹配子串group(0): ,位置為:(3, 3)
    匹配子串group(1): ,位置為:(3, 3)
>>> 
>>> parsematch('(?P
                
                  Lao)(?P
                  
                    \w+)(Python)','LaoYuanPython')
第1次匹配,匹配情況:
    匹配子串group(0): LaoYuanPython,位置為:(0, 13)
    匹配子串group(1): Lao,位置為:(0, 3)
    匹配子串group(2): Yuan,位置為:(3, 7)
    匹配子串group(3): Python,位置為:(7, 13)
>>>

                  
                
              
            
          

不過(guò)上述分析過(guò)程僅用于多次搜索到目標(biāo)串的時(shí)候才有作用,如果只是一次匹配到一個(gè)目標(biāo)串,則無(wú)需使用該方法,因?yàn)槭褂闷ヅ鋵?duì)象就很方便的查看匹配信息。

老猿Python,跟老猿學(xué)Python!
博客地址:https://blog.csdn.net/LaoYuanPython
請(qǐng)大家多多支持,點(diǎn)贊、評(píng)論和加關(guān)注!謝謝!


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦?。?!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論