這篇文章主要介紹“Python的compile函數(shù)語法是什么”,在日常操作中,相信很多人在Python的compile函數(shù)語法是什么問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Python的compile函數(shù)語法是什么”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
成都創(chuàng)新互聯(lián)是一家專業(yè)提供紅古企業(yè)網(wǎng)站建設(shè),專注與做網(wǎng)站、成都網(wǎng)站制作、H5開發(fā)、小程序制作等業(yè)務(wù)。10年已為紅古眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站設(shè)計公司優(yōu)惠進(jìn)行中。
compile 函數(shù)用于編譯正則表達(dá)式,生成一個正則表達(dá)式( Pattern )對象,供 match() 和 search() 這兩個函數(shù)使用。
語法格式為:
re.compile(pattern[, flags])
參數(shù):
pattern : 一個字符串形式的正則表達(dá)式
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 為了增加可讀性,忽略空格和' # '后面的注釋
>>>importre
>>>pattern =re.compile(r'\d+') # 用于匹配至少一個數(shù)字
>>>m =pattern.match('one12twothree34four') # 查找頭部,沒有匹配
>>>print(m)
None
>>>m =pattern.match('one12twothree34four',2,10)# 從'e'的位置開始匹配,沒有匹配
>>>print(m)
None
>>>m =pattern.match('one12twothree34four',3,10)# 從'1'的位置開始匹配,正好匹配
>>>print(m) # 返回一個 Match 對象<_sre.SRE_Matchobjectat0x10a42aac0
> >>>m.group(0) # 可省略 0
'12'
>>>m.start(0) # 可省略 0
3
>>>m.end(0) # 可省略 0
5
>>>m.span(0) # 可省略 0
(3,5)
在上面,當(dāng)匹配成功時返回一個 Match 對象,其中:
group([group1, …])
方法用于獲得一個或多個分組匹配的字符串,當(dāng)要獲得整個匹配的子串時,可直接使用 group()
或 group(0)
;
start([group])
方法用于獲取分組匹配的子串在整個字符串中的起始位置(子串第一個字符的索引),參數(shù)默認(rèn)值為 0;
end([group])
方法用于獲取分組匹配的子串在整個字符串中的結(jié)束位置(子串最后一個字符的索引+1),參數(shù)默認(rèn)值為 0;
span([group])
方法返回 (start(group), end(group))
。
到此,關(guān)于“Python的compile函數(shù)語法是什么”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
當(dāng)前標(biāo)題:Python的compile函數(shù)語法是什么
文章路徑:http://weahome.cn/article/jopsdp.html