中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python中re模塊如何使用

發布時間:2021-07-10 15:24:20 來源:億速云 閱讀:141 作者:Leah 欄目:互聯網科技

python中re模塊如何使用,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

re模塊簡介

re模塊是python官方自帶的模塊,安裝好python即可以import re。

re模塊內部封裝了很多關于正則表達式的函數,用來實現正則表達式全部功能。re模塊應用的場合非常多,務必多學多練,這樣才能真正掌握re模塊。

常用函數

findall

參數說明

re.findall(pattern, string, flags=0)

patten:正則表達式。

string:要匹配的字符串。

flags:標志位,用于控制正則表達式的匹配方式,如:是否區分大小寫,多行匹配等等。

返回值

從字符串開頭開始匹配,一直匹配到結尾都匹配不到結果則返回None;匹配到結果則返回字符串列表(可匹配多個結果)。

用途

從字符串中按正則表達式查找或提取內容。

案例

import re

result = re.findall('\d+','123abc567def98')print(result)out:['123', '567', '98']

search

參數說明

參數和findall完全一致。

返回值

從字符串開頭開始匹配,一直匹配到結尾都匹配不到結果則返回None;匹配到結果則返回re.Match對象(只匹配一個結果)。

re.Match對象的span第一個值是首個匹配成功位置,第二個值是匹配結束后1位。 match保存了匹配到的內容。

使用變量名.group()方法可提取匹配到的結果。

用途

查找字符串中是否存在符合正則表達式的內容。

案例

result1 = re.search('\d+','123abc567def98')print(result1)print(result1.group())result2 = re.search('\d+','abc567def98')print(result2)print(result2.group())out:<re.Match object; span=(0, 3), match='123'>   123<re.Match object; span=(3, 6), match='567'>567

match

參數說明

參數和findall完全一致。

返回值

返回值和search基本一致。區別在于match是開頭匹配不到就會返回None;而search是開頭匹配不到會繼續向后匹配直到匹配成功或者匹配結束。

用途

校驗用戶輸入的內容是否符合正則表達式。

案例

result1 = re.match('\d+','123abc567def98')print(result1)print(result1.group())result2 = re.match('\d+','abc567def98')print(result2)if result2:  # 匹配失敗時result2的值是None,打印group會報錯。print(result2.group())out:<re.Match object; span=(0, 3), match='123'>123None

split

參數說明

re.split(pattern, string, maxsplit=0, flags=0)

patten:正則表達式。

string:要匹配的字符串。

maxsplit:切割參數,默認值0表示不限制次數,可傳參指定切割次數。

flags:標志位,用于控制正則表達式的匹配方式,如:是否區分大小寫,多行匹配等等。

返回值

返回值是字符串列表,可能會存在空字符元素。

用途

根據正則表達式對字符串進行切割。

案例

result1 = re.split('\d+','123abc567def98ghi')
print(result1)
result2 = re.split('[a-z]','123abc567def98ghi')
print(result2)
result3 = re.split('\w','123abc567def98ghi')
print(result3)

out:
['', 'abc', 'def', 'ghi']
['123', '', '', '567', '', '', '98', '', '', '']
['', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '', '']

補充

由于re.split切割會生成空字符串,所以經常會有去除列表中空字符串的需求,在此補充一下去除列表中空字符串的代碼。

result1 = list(filter(lambda x: x, result1))result2 = list(filter(lambda x: x, result2))result3 = list(filter(lambda x: x, result3))print(result1)print(result2)print(result3)out:['abc', 'def', 'ghi']['123', '567', '98'][]

關于python中re模塊如何使用問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

咸丰县| 图片| 仁布县| 巧家县| 高清| 青浦区| 鹿邑县| 定西市| 博爱县| 洛南县| 白沙| 娱乐| 砚山县| 万安县| 司法| 弥渡县| 滕州市| 类乌齐县| 武宁县| 望谟县| 准格尔旗| 甘孜县| 九台市| 永靖县| 康保县| 石楼县| 许昌市| 株洲县| 宜宾市| 阿克苏市| 林甸县| 馆陶县| 营口市| 禹州市| 莲花县| 武平县| 浙江省| 通化市| 沙雅县| 大新县| 广昌县|