<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
它在re.py中有定義:
def findall(pattern, string, flags=0): """Return a list of all non-overlapping matches in the string. If one or more capturing groups are present in the pattern, return a list of groups; this will be a list of tuples if the pattern has more than one group. Empty matches are included in the result.""" return _compile(pattern, flags).findall(string)
返回string中所有與pattern匹配的全部字串,返回形式為陣列。
findall()函數的兩種表示形式
import re kk = re.compile(r'd+') kk.findall('one1two2three3four4') #[1,2,3,4] #注意此處findall()的用法,可傳兩個引數; kk = re.compile(r'd+') re.findall(kk,"one123") #[1,2,3]
後面會講解程式碼裡的各個部分,先列出來~
import re str = 'aabbabaabbaa' # 一個"."就是匹配除 n (換行符)以外的任意一個字元 print(re.findall(r'a.b',str))#['aab', 'aab'] # *前面的字元出現0次或以上 print(re.findall(r'a*b',str))#['aab', 'b', 'ab', 'aab', 'b'] # 貪婪,匹配從.*前面為開始到後面為結束的所有內容 print(re.findall(r'a.*b',str))#['aabbabaabb'] # 非貪婪,遇到開始和結束就進行擷取,因此擷取多次符合的結果,中間沒有字元也會被擷取 print(re.findall(r'a.*?b',str))#['aab', 'ab', 'aab'] # 非貪婪,與上面一樣,只是與上面的相比多了一個括號,只保留括號的內容 print(re.findall(r'a(.*?)b',str))#['a', '', 'a'] str = '''aabbab aabbaa bb''' #後面多加了2個b # 沒有把最後一個換行的aab算進來 print(re.findall(r'a.*?b',str))#['aab', 'ab', 'aab'] # re.S不會對n進行中斷 print(re.findall(r'a.*?b',str,re.S))#['aab', 'ab', 'aab', 'aan b']
字串是
str = 'aabbabaabbaa'
1. 符號 . 就 是匹配除 n (換行符)以外的任意一個字元
print(re.findall(r'a.b',str)) #['aab', 'aab']
2.符號 * 前面的字元出現0次或以上
print(re.findall(r'a*b',str)) #['aab', 'b', 'ab', 'aab', 'b']
3.符號.* 貪婪,匹配從.*前面為開始到後面為結束的所有內容
print(re.findall(r'a.*b',str)) #['aabbabaabb']
4.符號.*? 非貪婪,遇到開始和結束就進行擷取,因此擷取多次符合的結果,中間沒有字元也會被擷取
print(re.findall(r'a.*?b',str)) #['aab', 'ab', 'aab']
5.符號(.*?) 非貪婪,與上面一樣,只是與上面的相比多了一個括號,只保留括號的內容
print(re.findall(r'a(.*?)b',str)) #['a', '', 'a']
關於帶括號與不帶括號的區別
import re string="abcdefg acbdgef abcdgfe cadbgfe" #不帶括號 regex=re.compile("((w+)s+w+)") print(regex.findall(string)) #輸出:[('abcdefg acbdgef', 'abcdefg'), ('abcdgfe cadbgfe', 'abcdgfe')] regex1=re.compile("(w+)s+w+") print(regex1.findall(string)) #輸出:['abcdefg', 'abcdgfe'] regex2=re.compile("w+s+w+") print(regex2.findall(string)) #輸出:['abcdefg acbdgef', 'abcdgfe cadbgfe']
實際上這並不是python特有的,這是正則所特有的 , 任何一門高階語言使用正則都滿足這個特點:有括號時只能匹配到括號中的內容,沒有括號【相當於在最外層增加了一個括號】。在正則裡面 "()" 代表的是分組的意思,一個括號代表一個分組,你只能匹配到 "()" 中的內容。
1.字串變為(後面多加了2個b)
str = '''aabbab aabbaa bb'''
2.引數無re.S,沒有把最後一個換行的aab算進來
print(re.findall(r'a.*?b',str)) #['aab', 'ab', 'aab']
3.引數有re.S,不會對n進行中斷
print(re.findall(r'a.*?b',str,re.S)) #['aab', 'ab', 'aab', 'aan b']
到此這篇關於Python正則表達re模組之findall()函數詳解的文章就介紹到這了,更多相關Python正則表達re模組findall()內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45