這篇文章給大家介紹如何在Python中使用re正則表達(dá)式模塊,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
10年積累的成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作經(jīng)驗(yàn),可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先網(wǎng)站設(shè)計(jì)后付款的網(wǎng)站建設(shè)流程,更有東山免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。python 中的正則跟其他語言相比略有差異:
1、替換字符串時(shí),替換的字符串可以是一個(gè)函數(shù)
2、split 函數(shù)可以指定分割次數(shù),這會(huì)導(dǎo)致有個(gè)坑
3、前項(xiàng)界定的表達(dá)式必須定長
下面詳細(xì)描述下 re 模塊的使用方法,其實(shí),注意上面提到的三點(diǎn)差異就好
1、match
說明:
re.match 嘗試從字符串的起始位置匹配一個(gè)模式,如果不是起始位置匹配成功的話,match()就返回 None。
語法:
re.match(pattern, string, flags=0)
flags為可選標(biāo)識,多個(gè)標(biāo)識可以通過按位或 (|) 來指定。如 re.I | re.M 被設(shè)置成 I 和 M 標(biāo)識:
修飾符 | 描述 |
re.I | 使匹配對大小寫不敏感 |
re.L | 做本地化識別(locale-aware)匹配 |
re.M | 多行匹配,影響 ^ 和 $ |
re.S | 使 . 匹配包括換行在內(nèi)的所有字符 |
re.U | 根據(jù)Unicode字符集解析字符。這個(gè)標(biāo)志影響 \w, \W, \b, \B. |
re.X | 該標(biāo)志通過給予你更靈活的格式以便你將正則表達(dá)式寫得更易于理解。 |
匹配成功re.match方法返回一個(gè)匹配的對象,可以使用group(num) 或 groups() 匹配對象函數(shù)來獲取匹配表達(dá)式。group() 或 group(0),返回整個(gè)正則表達(dá)式的匹配結(jié)果。
舉例:
s= 'abc123abc' print(re.match('[a-z]+', s)) # <_sre.SRE_Match object; span=(0, 3), match='abc'> print(re.match('[a-z]+', s).group(0)) # abc print(re.match('[\d]+', s)) # None print(re.match('[A-Z]+', s, re.I).group(0)) # abc print(re.match('[a-z]+', s).span()) # (0, 3)
2、search
說明:
re.search 掃描整個(gè)字符串并返回第一個(gè)成功的匹配。
語法:
re.search(pattern, string, flags=0)
匹配成功re.search方法返回一個(gè)匹配的對象,否則返回None??梢允褂胓roup(num) 或 groups() 匹配對象函數(shù)來獲取匹配表達(dá)式。
s = 'abc123abc' print(re.search('[a-z]+', s).group()) # abc print(re.search('[a-z]+', s).span()) # (0, 3) print(re.search('[\d]+', s).group()) # 123 print(re.search('[\d]+', s).span()) # (3, 6) print(re.search('xyz', s)) # None
groupdict
groupdict 返回匹配到的所有命名子組的字典。
print(re.search('[a-z]+', s).groupdict()) # {} print(re.search('(?P[a-z]+)(?P \d+)', s).groupdict()) # {'num': '123', 'letter': 'abc'}
3、sub 和 subn
說明:
re.sub用于替換字符串中的匹配項(xiàng)。
re.subn返回一個(gè)元組,包含替換后的字符串及替換次數(shù)。
語法:
sub(pattern, repl, string, count=0, flags=0)
repl: 替換的字符串,也可為一個(gè)函數(shù)。
count: 模式匹配后替換的大次數(shù),默認(rèn) 0 表示替換所有的匹配。
舉例:
s = 'abc123abc' print(re.sub('[\d]+', '數(shù)字', s)) # abc數(shù)字abc print(re.sub('[a-z]+', '字母', s, 1)) # 字母123abc # 將匹配的數(shù)字乘以 2 def double(matched): value = int(matched.group('value')) return str(value * 2) # repl是一個(gè)函數(shù) print(re.sub('(?P\d+)', double, s)) # abc246abc print(re.subn('[\d]+', '數(shù)字', s)) # ('abc數(shù)字abc', 1) print(re.subn('[a-z]+', '字母', s,)) # ('字母123字母', 2) print(re.subn('[a-z]+', '字母', s, 1)) # ('字母123字母', 1)
4、compile
說明:
re.compile 用于編譯正則表達(dá)式,生成一個(gè)正則表達(dá)式(Pattern)對象,供 match() 和 search() 這兩個(gè)函數(shù)使用。
語法:
compile(pattern, flags=0)
舉例:
s = 'abc123abc' p = re.compile('[\d]+') print(p.match(s, 4, 5).group(0)) # 2 從位置4開始匹配到位置5 print(p.search(s).group(0)) # 123
5、findall
說明:
re.findall 在字符串中查找正則表達(dá)式所匹配的所有子串,并返回一個(gè)列表,如果沒有找到匹配的,則返回空列表。
語法:
findall(pattern, string, flags=0)
舉例:
s = 'abc123abc' print(re.findall('[a-z]+', s)) # ['abc', 'abc'] print(re.findall('[h-n]+', s)) # []
6、finditer
說明:
finditer和 findall 類似,在字符串中查找正則表達(dá)式所匹配的所有子串,并把它們作為一個(gè)迭代器返回。
語法:
finditer(pattern, string, flags=0)
舉例:
s = 'abc123def' it = re.finditer('[a-z]+', s) for match in it: print(match.group())
7、split
說明:
re.split 方法按照能夠匹配的子串將字符串分割后返回列表。
語法:
split(pattern, string, maxsplit=0, flags=0)
maxsplit:分隔次數(shù),maxsplit=1 分隔一次,默認(rèn)為 0,不限制次數(shù)。
舉例:
print(re.split('a', '1A1a2A3', re.I)) # ['1A1', '2A3'] # 輸出結(jié)果并未能區(qū)分大小寫,這是因?yàn)閞e.split(pattern,string,maxsplit, flags)默認(rèn)是四個(gè)參數(shù),當(dāng)我們傳入的三個(gè)參數(shù)的時(shí)候,系統(tǒng)會(huì)默認(rèn)re.I是第三個(gè)參數(shù),所以就沒起作用。 # 如果想讓這里的re.I起作用,寫成flags=re.I即可。 print(re.split('a', '1A1a2A3', flags=re.I)) # ['1', '1', '2', '3']
8、escape
說明:
re.escape對字符串里面的特殊字符串進(jìn)行轉(zhuǎn)義。
語法:
escape(pattern)
舉例:
print(re.escape('www.dxy.cn')) # www\.dxy\.cn
9、正則
“(?P
“(?P=name)”:引用別名為
10、前項(xiàng)(否定)界定中的特殊
正則中常用的前項(xiàng)界定(?<=exp)和前項(xiàng)否定界定(?
(?<=aaa) # 正確 (?<=aaa|bbb) # 正確 (?<=aaa|bb) # 錯(cuò)誤 (?<=\d+) # 錯(cuò)誤 (?<=\d{3}) # 正確
關(guān)于如何在Python中使用re正則表達(dá)式模塊就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。