欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2022年05月16日 14:24:06   作者:Rustone  
這篇文章主要介紹了Python3中的re.findall()方法及re.compile(),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

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

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

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

findall(patern, string, flags=0)
  • pattern : 正則中的模式字符串。
  • string : 要被查找替換的原始字符串。
  • flags : 標志位,用于控制正則表達式的匹配方式,如:是否區(qū)分大小寫,多行匹配等等。

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

整個正則表達式執(zhí)行了,只不過只輸出括號匹配到的內容,即輸出的是第一個 (\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個括號,其輸出的內容就是括號匹配到的內容,而不是整個表達式所匹配到的結果。
  • 第三個正則表達式中不帶有括號,其輸出的內容就是整個表達式所匹配到的內容。

結論:findall()返回的是括號所匹配到的結果(如regex1),多個括號就會返回多個括號分別匹配到的結果(如regex),如果沒有括號就返回就返回整條語句所匹配到的結果(如regex2)。所以在提取數據的時候就需要注意這個坑。

實際上是由其并不是python特有的,這是 正則 所特有的 , 任何一門高級語言使用正則都滿足這個特點:有括號時只能匹配到括號中的內容,沒有括號【相當于在最外層增加了一個括號】。在正則里面 “()” 代表的是分組的意思,一個括號代表一個分組,你只能匹配到"()"中的內容

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • PyQT5 實現快捷鍵復制表格數據的方法示例

    PyQT5 實現快捷鍵復制表格數據的方法示例

    這篇文章主要介紹了PyQT5 實現快捷鍵復制表格數據的方法示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-06-06
  • 基于python調用jenkins-cli實現快速發(fā)布

    基于python調用jenkins-cli實現快速發(fā)布

    這篇文章主要介紹了基于python調用jenkins-cli實現快速發(fā)布,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-08-08
  • Python通過調用mysql存儲過程實現更新數據功能示例

    Python通過調用mysql存儲過程實現更新數據功能示例

    這篇文章主要介紹了Python通過調用mysql存儲過程實現更新數據功能,結合實例形式分析了Python調用mysql存儲過程實現更新數據的具體步驟與相關操作技巧,需要的朋友可以參考下
    2018-04-04
  • Python OpenCV之圖片縮放的實現(cv2.resize)

    Python OpenCV之圖片縮放的實現(cv2.resize)

    這篇文章主要介紹了Python OpenCV之圖片縮放的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-06-06
  • Python PyQt5實戰(zhàn)項目之網速監(jiān)控器的實現

    Python PyQt5實戰(zhàn)項目之網速監(jiān)控器的實現

    PyQt5以一套Python模塊的形式來實現功能。它包含了超過620個類,600個方法和函數。它是一個多平臺的工具套件,它可以運行在所有的主流操作系統(tǒng)中,包含Unix,Windows和Mac OS。PyQt5采用雙重許可模式。開發(fā)者可以在GPL和社區(qū)授權之間選擇
    2021-11-11
  • pytest全局變量的使用詳解

    pytest全局變量的使用詳解

    全局變量是在函數外部定義的變量,所有函數內部都可以使用這個變量,本文就來介紹一下pytest全局變量的使用,感興趣的可以了解一下
    2023-11-11
  • Python 使用type來定義類的實現

    Python 使用type來定義類的實現

    今天小編就為大家分享一篇Python 使用type來定義類的實現,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • python元組操作實例解析

    python元組操作實例解析

    這篇文章主要介紹了python元組操作,以實例的形式較為直觀的講述了Python中元組的特點與用法,需要的朋友可以參考下
    2014-09-09
  • python繪制柱狀圖的方法

    python繪制柱狀圖的方法

    這篇文章主要為大家詳細介紹了python繪制柱狀圖的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • Python Numpy 實現交換兩行和兩列的方法

    Python Numpy 實現交換兩行和兩列的方法

    今天小編就為大家分享一篇Python Numpy 實現交換兩行和兩列的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-06-06

最新評論