溫馨提示×

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

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

Python中re模塊匹配方法怎么用

發(fā)布時(shí)間:2022-08-26 11:35:34 來(lái)源:億速云 閱讀:167 作者:iii 欄目:開(kāi)發(fā)技術(shù)

這篇文章主要介紹了Python中re模塊匹配方法怎么用的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇Python中re模塊匹配方法怎么用文章都會(huì)有所收獲,下面我們一起來(lái)看看吧。

匹配開(kāi)頭結(jié)尾

字符功能
^匹配字符串開(kāi)頭
$匹配字符串結(jié)尾

示例1:$

需求:匹配163.com的郵箱地址

email_list = [ " xiaoWang@163.com " , " xiaoWang@163.comh eihei" , ". com.xiaowang@qq.com " ]

for email in email_list:
    ret = re.match("[\w]{4,20}@163\.com$", email) \.代表只是一個(gè)點(diǎn) $代表以xxx結(jié)尾的字符串
    if ret:
        print("%s ---是符合規(guī)定的郵件地址” % email)
    else:
        print("%s ---不符合要求" % email)

運(yùn)行結(jié)果:

xiaoWang@163.com            # ---是符合規(guī)定的郵件地址
xiaoWang@163.comheihei      # ---不符合要求   # 如果沒(méi)有$,這個(gè)字符串會(huì)匹配出來(lái)
.com.xiaowang@qq.com        # ---不符合要求

匹配分組

字符功能
|匹配左右任意一個(gè)表達(dá)式
(ab)將括號(hào)中字符作為一個(gè)分組
\num引用分組num匹配到的字符串
(?P<name>)分組起別名
(?P=name)引用別名為name分組匹配到的字符串

示例1:|

需求:匹配出0-100之間的數(shù)字

#coding=utf-8
import re
 
ret = re.match("[1-9]?\d","8”) # ?匹配前面的字符出現(xiàn)1次或者0次 類似78也可以匹配
print(ret.group())  
# 結(jié)果:8
# 可能匹配不成功時(shí)?
 import re
 
ret = re.match("[1-9]?\d$","08")
if ret:
    print(ret.group())
else:
    print("不在0-100之間”)           
# 結(jié)果:不在0-100之間

# 添加|

import re
ret = re.match("[1-9]?\d$|100","78")
print(ret.group())                           
# 結(jié)果: 78
 
ret = re.match("[1-9]?\d$|100","100")
print(ret.group())                         
# 結(jié)果: 100

示例2:( )

需求:匹配出163、126、qq郵箱

#coding=utf-8
import re

ret = re.match("\w{4,20}@163\.com", "test@163.com”)  
print(ret.group())                               
# 結(jié)果: test@163.com
ret = re.match("\w{4,20}@(163|126|qq)\.com", "test@gmail.com")
if ret:
    print(ret.group())
else:
    print("不是163、126、qq郵箱")                  
# 結(jié)果: 不是163、126、qq郵箱

需求:不是以4、7結(jié)尾的手機(jī)號(hào)碼(11位)

import re
tels = ["13100001234", "18912344321", "10086", "18800007777"]
 
for tel in tels:
    ret = re.match("1\d{9}[0-3,5-6,8-9]", tel)
    if ret:
        print(ret.group())
    else:
        print("%s 不是想要的手機(jī)號(hào)" % tel)

結(jié)果如下:

13100001234 不是想要的手機(jī)號(hào)
18912344321
10086 不是想要的手機(jī)號(hào)
18800007777 不是想要的手機(jī)號(hào)

示例三:分組匹配

需求:提取區(qū)號(hào)和電話號(hào)碼

import re
ret = re.match("([^-]*)-(\d+)", "010-12345678") 
print(ret.group())
print(ret.group(1))
print(ret.group(2))

結(jié)果如下:

010-12345678
010
12345678

^在[ ]里面代表非的含義:

例如:

  • [^-]*   *代表前所有字符0個(gè)或者多個(gè),非-的字符串

  • [^abc]  代表非a、且非b 、且非c的字符

關(guān)于“Python中re模塊匹配方法怎么用”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“Python中re模塊匹配方法怎么用”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

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

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

AI