溫馨提示×

溫馨提示×

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

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

如何正確的使用Python元字符

發(fā)布時間:2021-01-11 15:41:40 來源:億速云 閱讀:178 作者:Leah 欄目:開發(fā)技術(shù)

今天就跟大家聊聊有關(guān)如何正確的使用Python元字符,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

反斜杠的作用:

要想將一個元字符^當(dāng)一個普通字符處理,加反斜杠

例如:

>>>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']

星號的作用:(*)

將前面的一個字符匹配零次或更多次。

>>>r=r'ab*'
>>>re.findall(r,'a')
['a']
>>>re.findall(r,'ab')
['ab']
>>>re.findall(r,'abbbbbb')
['abbbbbb']

加號的作用:(+)

表示匹配一次或更多次。

>>>r=r'ab+'
>>>re.findall(r,'a')
[]
>>>re.findall(r,'ab')
['ab']
>>>re.findall(r,'abbbb')
['abbbb']

電話號碼中間的“-”問題:(可有可無)

>>>r=r'^010-*\d{8}'
>>>re.findall(r,'010-12345678')
['010-12345678']
>>>re.findall(r,'01012345678')
['01012345678']
>>>re.findall(r,'010---12345678')
['010---12345678']

問號的作用:(?)

匹配一次或零次;

>>>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']

非貪婪模式匹配,用問號做最小匹配,如下:

>>>r=r'ab+?'
>>>re.findall(r,'abbbbbbbbbbb')
['ab']

>>>r=r'ab*?'
>>>re.findall(r,'abbbbbbbbbbbb')
['a']

花括號的用法:({m,n})

其中m和n是十進(jìn)制整數(shù)。該限定符的意思是至少有m個重復(fù),至多有n個重復(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)表示一個分組;分組中做**或**操作,要么是.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']      #做匹配的時候優(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)用

看完上述內(nèi)容,你們對如何正確的使用Python元字符有進(jìn)一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI