溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python3中的re.findall()及re.compile()方法怎么用

發布時間:2022-05-16 15:55:20 來源:億速云 閱讀:418 作者:iii 欄目:開發技術

這篇文章主要講解了“Python3中的re.findall()及re.compile()方法怎么用”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Python3中的re.findall()及re.compile()方法怎么用”吧!

    re.findall()方法及re.compile()

    • re.findall()在字符串中找到正則表達式所匹配的所有子串,并返回一個列表;如果沒有找到匹配的,則返回空列表。

    返回結果是列表類型,需要遍歷一下才能依次獲取每組內容。

    findall(patern, string, flags=0)
    • pattern : 正則中的模式字符串。

    • string : 要被查找替換的原始字符串。

    • flags : 標志位,用于控制正則表達式的匹配方式,如:是否區分大小寫,多行匹配等等。

    1.例子

    import re 
    content = 'Hello 123456789 Word_This is just a test 666 Test'
    results = re.findall('\d+', content)    
     
    print(results)
    for result in results:
        print(result)

    結果:

    ['123456789', '666']
    123456789
    666
     
    Process finished with exit code 0

    注意利用re.findall()函數沒有group()和groups(),因為其返回結果是一個列表。

    2.re.compile()方法

    • re.compile()方法可以將正則字符串編譯成正則表達式對象,以便在后面的匹配中復用。

    re.compile(pattern[, flags])

    re.compile()中可以傳入忽略換行等匹配模式,這樣在search()、findall()方法中就不需要額外傳入了。

    因此,re.findall()方法有2種表達方式:

    import re
     
    content = 'one1two22three333four4444'
    pattern = re.compile(r'\d+')
    print('===方法1:===')
    result1 = re.findall(pattern, content)
    print(result1)
     
    print('===方法2===')
    result2 = pattern.findall(content)
    print(result2)

    結果:

    ===方法1:===
    ['1', '22', '333', '4444']
    ===方法2===
    ['1', '22', '333', '4444']
     
    Process finished with exit code 0

    3.在使用findall()方法時的“坑”

    注意正則表達式中括號()的使用

    (1)正則表達式中當沒有括號時,正常匹配:

    import re 
     
    str1 = '2345  3456  4567  5678  6789'
    pattern_1 = re.compile('\w+\s+\w+') # \w 表示匹配包括下劃線的任何單詞字符,等價于[A-Za-z0-9_]
    print(pattern_1.findall(str1))

    結果:

    ['2345  3456', '4567  5678']
     
    Process finished with exit code 0

    (2)正則表達式中有一個括號時,其輸出的內容就是括號匹配到的內容,而不是整個表達式所匹配到的結果:

    import re
     
    str1 = '2345  3456  4567  5678  6789'
    pattern_1 = re.compile('(\w+)\s+\w+') # \w 表示匹配包括下劃線的任何單詞字符,等價于[A-Za-z0-9_]
    print(pattern_1.findall(str1))

    結果:

    ['2345', '4567']
     
    Process finished with exit code 0

    整個正則表達式執行了,只不過只輸出括號匹配到的內容,即輸出的是第一個 (\w+) 匹配到的內容:

    在第一次匹配時跟上述沒有括號時一樣,匹配到"2345 3456",只不過只輸出(/w+)匹配到的結果 即"2345";

    第二次匹配同理,從"4567" 開始,匹配到"4567  5678",但是還是只是輸出(/w+)匹配到的結果 即"4567"。

    (3)當正則表達式中有兩個括號時,其輸出是一個list 中包含2個 tuple:

    import re
     
    str1 = '2345  3456  4567  5678  6789'
    pattern_1 = re.compile('((\w+)\s+\w+)') # \w 表示匹配包括下劃線的任何單詞字符,等價于[A-Za-z0-9_]
    print(pattern_1.findall(str1))

    結果:

    [('2345  3456', '2345'), ('4567  5678', '4567')]
     
    Process finished with exit code 0

    從輸出的結果可以看出,結果中包含兩個元組,每一個元組中有兩個字符串。

    第一個元組是第一次匹配的結果,其中的第一個字符串 "2345 3456" 是正則表達式最外面的括號

    • ((\w+)\s+\w+)

    匹配輸出的結果;

    第一個元組中的第二個字符串 "2345"是正則表達式里面括號

    • (\w+)

    匹配輸出的結果 ;

    第二個元組是第二次匹配的結果,匹配原理與第一次匹配相同。

    正則表達式findall函數問題

    在寫正則表達式的時候總會遇到不少的問題, 特別是在表達式有多個元組的時候。下面看下re模塊下的findall()函數和多個表達式元組相遇的時候會出現什么樣的坑。

    代碼如下:    

    import re
    str="a b c d"
    regex0=re.compile("((\w )\s \w )")
    print(regex0.findall(str))
    regex1=re.compile("(\w )\s \w ")
    print(regex1.findall(str))
    regex2=re.compile("\w \s \w ")
    print(regex2.findall(str))

    結果:    

    [('a b', 'a'), ('c d', 'c')]
    ['a', 'c']
    ['a b', 'c d']

    可能結果有點意外,下面解釋一下

    • 第一個正則表達式中是帶有2個括號的,我們可以看到其輸出是一個list 中包含2個 tuple

    • 第二個正則表達式中帶有1個括號,其輸出的內容就是括號匹配到的內容,而不是整個表達式所匹配到的結果。

    • 第三個正則表達式中不帶有括號,其輸出的內容就是整個表達式所匹配到的內容。

    感謝各位的閱讀,以上就是“Python3中的re.findall()及re.compile()方法怎么用”的內容了,經過本文的學習后,相信大家對Python3中的re.findall()及re.compile()方法怎么用這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女