python re.match函數(shù)的具體使用
1 re.match 說明
re.match() 從開始位置開始往后查找,返回第一個符合規(guī)則的對象,如果開始位置不符合匹配隊形則返回None
從源碼里面看下match 里面的內(nèi)容

里面有3個參數(shù) pattern ,string ,flags
pattern : 是匹配的規(guī)則內(nèi)容
string : 要匹配的字符串
flag : 標(biāo)志位(這個是可選的,可寫,可不寫),用于控制正則表達(dá)式的匹配方式,如:是否區(qū)分大小寫,多行匹配等等
下面寫一個demo
str_content = "Python is a good language" # 要匹配的內(nèi)容, 對應(yīng)match 里面的string
str_pattern = "Python" # pattern 匹配的規(guī)則
re_content = re.match("Python", str_content)
print(re_content)打印的結(jié)果如下

可以看到匹配的的下標(biāo)是(0,6) 匹配的內(nèi)容是Python
2 span 的使用
如果想獲取匹配的下標(biāo),可以使用span ,
match span 的作用就是返回匹配到內(nèi)容的下標(biāo)
使用方式如下
import re # 導(dǎo)入re 模塊
str_content = "Python is a good language" # 要匹配的內(nèi)容, 對應(yīng)match 里面的string
str_pattern = "Python" # pattern 匹配的規(guī)則
re_content = re.match("Python", str_content).span()
print(re_content)打印結(jié)果如下

3 group 的使用
如果想獲取匹配到結(jié)果的內(nèi)容可以使用group ,注意使用group的時候就不要在使用span 了
import re # 導(dǎo)入re 模塊
str_content = "Python is a good language" # 要匹配的內(nèi)容, 對應(yīng)match 里面的string
str_pattern = "Python" # pattern 匹配的規(guī)則
re_content = re.match("Python", str_content)
print(re_content.group())打印結(jié)果如下

4 匹配不到內(nèi)容的情況
如下面的返回結(jié)果為None
import re # 導(dǎo)入re 模塊
str_content = "Python is a good language" # 要匹配的內(nèi)容, 對應(yīng)match 里面的string
str_pattern = "Python" # pattern 匹配的規(guī)則
re_content = re.match("python", str_content)
print(re_content)
# 或者
str_content = "Python is a good language" # 要匹配的內(nèi)容, 對應(yīng)match 里面的string
str_pattern = "Python" # pattern 匹配的規(guī)則
re_content = re.match("is", str_content)
print(re_content)5 使用group 注意點(diǎn)
注意當(dāng)匹配不到內(nèi)容的時候就使用group 或者span 的時候會報錯,所以當(dāng)使用group 的時候 先判斷下是否匹配到內(nèi)容然后在使用它
例如匹配不到內(nèi)容的情況下使用group
import re # 導(dǎo)入re 模塊
str_content = "Python is a good language" # 要匹配的內(nèi)容, 對應(yīng)match 里面的string
str_pattern = "Python" # patterPn 匹配的規(guī)則
re_content = re.match("python", str_content)
print(re_content.group())這樣會報錯,報錯內(nèi)容如下

添加是否匹配判斷
import re # 導(dǎo)入re 模塊
str_content = "Python is a good language" # 要匹配的內(nèi)容, 對應(yīng)match 里面的string
str_pattern = "Python" # patterPn 匹配的規(guī)則
re_content = re.match("python", str_content)
if re_content:
print(re_content.group())
else:
print("沒有匹配到內(nèi)容")打印結(jié)果如下

這樣會走到else 里面就不會報錯了
6 flag 的使用
寫一個忽略大小寫的情況
import re # 導(dǎo)入re 模塊
str_content = "Python is a good language" # 要匹配的內(nèi)容, 對應(yīng)match 里面的string
str_pattern = "Python" # patterPn 匹配的規(guī)則
re_content = re.match("python", str_content, re.I)
if re_content:
print(re_content.group())
else:
print("沒有匹配到內(nèi)容")打印結(jié)果如下:

flags : 可選,表示匹配模式,比如忽略大小寫,多行模式等,具體參數(shù)為:
- re.I 忽略大小寫
- re.L 表示特殊字符集 \w, \W, \b, \B, \s, \S 依賴于當(dāng)前環(huán)境
- re.M 多行模式
- re.S 即為 . 并且包括換行符在內(nèi)的任意字符(. 不包括換行符)
- re.U 表示特殊字符集 \w, \W, \b, \B, \d, \D, \s, \S 依賴于 Unicode 字符屬性數(shù)據(jù)庫
- re.X 為了增加可讀性,忽略空格和 # 后面的注釋
到此這篇關(guān)于python re.match函數(shù)的具體使用的文章就介紹到這了,更多相關(guān)python re.match內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
keras的ImageDataGenerator和flow()的用法說明
這篇文章主要介紹了keras的ImageDataGenerator和flow()的用法說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07
python 實現(xiàn)多線程的三種方法總結(jié)
這篇文章主要介紹了python 實現(xiàn)多線程的三種方法總結(jié),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-04-04
端午節(jié)將至,用Python爬取粽子數(shù)據(jù)并可視化,看看網(wǎng)友喜歡哪種粽子吧!
端午節(jié)快要到了,旅游?回家?拜訪親友?少不了要帶上粽子.那么:選擇什么牌子的粽子呢?選擇什么口味的粽子呢?選擇什么價格區(qū)間呢?今天爬取了京東上面的 “粽子數(shù)據(jù)” 進(jìn)行分析,看看有啥發(fā)現(xiàn)吧!,需要的朋友可以參考下2021-06-06
基于Python數(shù)據(jù)結(jié)構(gòu)之遞歸與回溯搜索
今天小編就為大家分享一篇基于Python數(shù)據(jù)結(jié)構(gòu)之遞歸與回溯搜索,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-02-02
python3.6之xlwt如何設(shè)置單元格對齊方式
這篇文章主要介紹了python3.6之xlwt如何設(shè)置單元格對齊方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06
從基礎(chǔ)到進(jìn)階帶你玩轉(zhuǎn)Python中的JSON
JSON是一種輕量級的數(shù)據(jù)交換格式,在Python中處理JSON數(shù)據(jù)是日常開發(fā)中的常見任務(wù)之一,本文將詳細(xì)介紹如何在Python中處理JSON對象,需要的可以參考下2024-12-12

