Python元字符的用法實(shí)例解析
反斜杠的作用:
要想將一個(gè)元字符^當(dāng)一個(gè)普通字符處理,加反斜杠
例如:
>>>import re >>>r=r'\^abc' >>>re.findall(r,'^abc ^abc ^abc') ['^abc','^abc','^abc']
\d匹配任何十進(jìn)制數(shù),它相當(dāng)于類[0-9].
\D匹配任何非數(shù)字字符,它相當(dāng)于類[^0-9]
\s匹配任何空白字符,他相當(dāng)于類[\t\n\r\f\v]
\S匹配任何非空白字符,它相當(dāng)于類[^\t\n\r\f\v]
\w匹配任何字母數(shù)字字符,它相當(dāng)于類[a-zA-Z0-9_]
\W匹配任何非字母數(shù)字字符,它相當(dāng)于類[^a-zA-Z0-9_]
>>>r=r'[0-9]' >>>re.findall(r,'1234567890') ['1','2','3','4','5','6','7','8','9','0'] >>>r=r'\d' >>>re.findall(r,'1234567890') ['1','2','3','4','5','6','7','8','9','0']
>>>r=r'^010-\d\d\d\d\d\d\d\d' >>>re.findall(r,'010-87654321') ['010-87654321'] >>>re.findall(r,'010-8765432') [] >>>r=r'^010-\d{8}'#重復(fù)八次 >>>re.findall(r,'010-12345678') ['^010-12345678']
星號(hào)的作用:(*)
將前面的一個(gè)字符匹配零次或更多次。
>>>r=r'ab*' >>>re.findall(r,'a') ['a'] >>>re.findall(r,'ab') ['ab'] >>>re.findall(r,'abbbbbb') ['abbbbbb']
加號(hào)的作用:(+)
表示匹配一次或更多次。
>>>r=r'ab+' >>>re.findall(r,'a') [] >>>re.findall(r,'ab') ['ab'] >>>re.findall(r,'abbbb') ['abbbb']
電話號(hào)碼中間的“-”問題:(可有可無)
>>>r=r'^010-*\d{8}' >>>re.findall(r,'010-12345678') ['010-12345678'] >>>re.findall(r,'01012345678') ['01012345678'] >>>re.findall(r,'010---12345678') ['010---12345678']
問號(hào)的作用:(?)
匹配一次或零次;
>>>r=r'^010-?\d{8}$' >>>re.findall(r,'010--12345678') [] >>>re.findall(r,'010-12345678') ['010-12345678'] >>>re.findall(r,'01012345678') ['01012345678']
做最小模式匹配:
貪婪模式匹配如下:
>>>r=r'ab+' >>>re.findall(r,'abbbbbbbbbbb') ['abbbbbbbbbbb']
非貪婪模式匹配,用問號(hào)做最小匹配,如下:
>>>r=r'ab+?' >>>re.findall(r,'abbbbbbbbbbb') ['ab'] >>>r=r'ab*?' >>>re.findall(r,'abbbbbbbbbbbb') ['a']
花括號(hào)的用法:({m,n})
其中m和n是十進(jìn)制整數(shù)。該限定符的意思是至少有m個(gè)重復(fù),至多有n個(gè)重復(fù)。
>>>r=r'a{1,3}'#表示a重復(fù)一到三次 >>>re.findall(r,'a') ['a'] >>>re.findall(r,'aa') ['aa'] >>>re.findall(r,'aaa') ['aaa'] >>>re.findall(r,'aaaa') ['aaa','a']
分組:“(”和“)”
>>> import re >>> email=r'\w{3}@\w+(\.com|\.cn)'#定義正則,(\.com|\.cn)表示一個(gè)分組;分組中做**或**操作,要么是.com,要么是.cn >>> re.match(email,'www@owolf.com')#進(jìn)行匹配 <_sre.SRE_Match object; span=(0, 13), match='www@owolf.com'> >>> re.match(email,'www@owolf.cn') <_sre.SRE_Match object; span=(0, 12), match='www@owolf.cn'> >>> re.match(email,'www@owolf.org') >>> #返回空值 >>> re.findall(email,'www@owolf.com') ['.com'] #做匹配的時(shí)候優(yōu)先返回分組中的數(shù)據(jù) >>> re.findall(email,'www@owolf.cn') ['.cn'] >>>
>>> s=''' ajhfa kasjf owolf english=chinese yes no print lafl int=456 yes float int=789 yes owolf english=france yes aklfl '''#定義字符串 >>> r=r'owolf english=.+ yes' #定義正則 >>> re.findall(r,s) #匹配正則 ['owolf english=chinese yes', 'owolf english=france yes'] >>> r=r'owolf english=(.+) yes' >>> re.findall(r,s) ['chinese', 'france'] #利用分組優(yōu)先返回分組中的數(shù)據(jù),在爬蟲中經(jīng)常應(yīng)用
總結(jié)
以上就是本文關(guān)于Python元字符的用法實(shí)例解析的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對(duì)本站的支持!
相關(guān)文章
python之np.argmax()及對(duì)axis=0或者1的理解
這篇文章主要介紹了python之np.argmax()及對(duì)axis=0或者1的理解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06Python實(shí)現(xiàn)的下載8000首兒歌的代碼分享
這篇文章主要介紹了Python實(shí)現(xiàn)的下載8000首兒歌的代碼分享,本文直接給出實(shí)現(xiàn)代碼,下載的是有伴網(wǎng)的資源,需要的朋友可以參考下2014-11-11pandas實(shí)現(xiàn)datetime64與unix時(shí)間戳互轉(zhuǎn)
這篇文章主要介紹了pandas實(shí)現(xiàn)datetime64與unix時(shí)間戳互轉(zhuǎn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07PyTorch 1.0 正式版已經(jīng)發(fā)布了
今天小編就為大家分享一篇關(guān)于PyTorch 1.0 正式版已經(jīng)發(fā)布了!小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2018-12-12Python?中的對(duì)象析構(gòu)函數(shù)__del__?詳情
這篇文章主要介紹了Python?中的對(duì)象析構(gòu)函數(shù)del詳情,Python?中的類的構(gòu)造函數(shù)???__init__???,?每當(dāng)實(shí)例產(chǎn)生就會(huì)調(diào)用這個(gè)構(gòu)造函下面更多相關(guān)內(nèi)容,需要的小伙伴可以參考一下2022-03-03Python打包工具PyInstaller的安裝與pycharm配置支持PyInstaller詳細(xì)方法
這篇文章主要介紹了Python打包工具PyInstaller的安裝與pycharm配置支持PyInstaller詳細(xì)方法,需要的朋友可以參考下2020-02-02PyTorch中torch.utils.data.DataLoader簡(jiǎn)單介紹與使用方法
DataLoader是PyTorch中讀取數(shù)據(jù)的一個(gè)重要接口,基本上用PyTorch訓(xùn)練模型都會(huì)用到,下面這篇文章主要給大家介紹了關(guān)于PyTorch中torch.utils.data.DataLoader簡(jiǎn)單介紹與使用方法的相關(guān)資料,需要的朋友可以參考下2022-06-06刪除DataFrame中值全為NaN或者包含有NaN的列或行方法
今天小編就為大家分享一篇?jiǎng)h除DataFrame中值全為NaN或者包含有NaN的列或行方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-11-11