python re.match函數(shù)的具體使用
1 re.match 說明
re.match() 從開始位置開始往后查找,返回第一個符合規(guī)則的對象,如果開始位置不符合匹配隊(duì)形則返回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)文章
利用Python計(jì)算質(zhì)數(shù)與完全數(shù)的方法實(shí)例
這篇文章主要介紹了利用Python計(jì)算質(zhì)數(shù)與完全數(shù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03總結(jié)Python函數(shù)參數(shù)的六種類型
這篇文章主要總結(jié)了Python函數(shù)參數(shù)的六種類型,傳遞參數(shù)實(shí)現(xiàn)不同場景的靈活使用,下面總結(jié)的六種函數(shù)參數(shù)類型,需要的小伙伴可以參考一下2022-03-03Python編程利用科赫曲線實(shí)現(xiàn)三維飄雪效果示例過程
這篇文章主要介紹了Python編程實(shí)現(xiàn)三維飄雪效果示例過程,通過本示例你可以自己做出一個浪漫的雪花飄落效果,有需要的朋友可以借鑒參考下2021-10-10django rest framework serializer返回時間自動格式化方法
這篇文章主要介紹了django rest framework serializer返回時間自動格式化方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03Python+Opencv實(shí)現(xiàn)圖像模板匹配詳解
模板匹配可以看作是對象檢測的一種非?;镜男问?。使用模板匹配,我們可以使用包含要檢測對象的“模板”來檢測輸入圖像中的對象。本文為大家介紹了圖像模板匹配的實(shí)現(xiàn)方法,需要的可以參考一下2022-09-09