Python中re.findAll()、re.sub()、set()的使用
1. re.findall()
re.findall():函數(shù)返回包含所有匹配項(xiàng)的列表。返回string中所有與pattern相匹配的全部字串,返回形式為list / 數(shù)組。
由函數(shù)原型代碼可知,findall() 函數(shù)存在三個(gè)參數(shù):
1. pattern:正則表達(dá)式中的 ‘模式字符串’ ;
2. string:當(dāng)前需要處理(查找替換)的原始字符串;
3. flags:可選參數(shù),表示編譯時(shí)用的匹配模式(如忽略大小寫、多行模式等),數(shù)字形式,默認(rèn)為0
# 示例代碼 import re text1 = '北京市海淀區(qū)不存在的38街區(qū)不想工作大廈99號(hào)' res = re.findall(r'\d+', text1) print(type(res)) print(res) # output # <class 'list'> # ['38', '99']
2. re.sub()
re.sub():函數(shù)將所有匹配項(xiàng),替換為選擇的文本,并返回結(jié)果。
由函數(shù)原型代碼可知,re.sub() 函數(shù)存在五個(gè)參數(shù):
1. pattern:正則表達(dá)式中的 ‘模式字符串’ ;
2. repl:需要被替換成的字符串,即將匹配到的pattern替換為repl;可以是函數(shù);
3. string:當(dāng)前需要處理(查找替換)的原始字符串;
4. count:可選參數(shù),表示需要替換的最大次數(shù),必須是非負(fù)整數(shù);默認(rèn)值為0,即匹配到的所有子串都進(jìn)行替換操作;
5. flags:可選參數(shù),表示編譯時(shí)用的匹配模式(如忽略大小寫、多行模式等),數(shù)字形式,默認(rèn)為0
# 將所有匹配到的‘?dāng)?shù)字串' 替換為 '520‘ text1 = '北京市海淀區(qū)不存在的38街區(qū)不想工作大廈99號(hào)' res = re.re(r'\d+', 520) print(type(res)) print(res) # output,返回值res結(jié)果是str # <class 'str'> # 北京市海淀區(qū)不存在的520街區(qū)不想工作大廈520號(hào)
3. set()
set():python內(nèi)置函數(shù)的其中一個(gè),創(chuàng)建一個(gè)無序不重復(fù)元素集。支持計(jì)算交集、差集、并并集。
# 為list數(shù)組l1 去重 l1 = [1, 1, 2, 2, 2, 3, 4] s1 = set(l1) print(type(s1)) print(s1) # output,返回類型是 set # <class 'set'> # {1, 2, 3, 4}
# 計(jì)算l1 和 l2 的交集 l1 = [1, 1, 2, 2, 2, 3, 4] l2 = [2, 3, 3, 4, 5, 6, 6] s1 = set(l1) s2 = set(l2) u = s1 & s2 print(type(u)) print(u) # output,返回結(jié)果類型set # <class 'set'> # {2, 3, 4}
# 計(jì)算l1 和 l2 的并集, 并集符號(hào) ‘|',intersection l1 = [1, 1, 2, 2, 2, 3, 4] l2 = [2, 3, 3, 4, 5, 6, 6] s1 = set(l1) # {1, 2, 3, 4} s2 = set(l2) # {2, 3, 4, 5, 6} u = s1 | s2 print(type(u)) print(u) # output,返回結(jié)果類型set, 計(jì)算 {1, 2, 3, 4} 和 {2, 3, 4, 5, 6} 的并集 # <class 'set'> # {1, 2, 3, 4, 5, 6}
# 計(jì)算差集,diff l1 = [1, 1, 2, 2, 2, 3, 4] l2 = [2, 3, 3, 4, 5, 6, 6] s1 = set(l1) # {1, 2, 3, 4} s2 = set(l2) # {2, 3, 4, 5, 6} print(s2) u = s1 - s2 print(type(u)) print(u) # output,返回結(jié)果是set # <class 'set'> # {1}
# set內(nèi)也可以傳入字符串,會(huì)自動(dòng)轉(zhuǎn)換成list類型 text1 = '北京市海淀區(qū)海淀區(qū)不想上班不想上班' res = set(text1) print(res) # 內(nèi)部元素是一個(gè)個(gè)的字,去重 且 無序 # output # <class 'set'> # {'上', '北', '班', '海', '淀', '京', '不', '想', '區(qū)', '市'}
到此這篇關(guān)于Python中re.findAll()、re.sub()、set()的使用的文章就介紹到這了,更多相關(guān)Python re.findAll()、re.sub()、set()內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
django rest framework 實(shí)現(xiàn)用戶登錄認(rèn)證詳解
這篇文章主要介紹了django rest framework 實(shí)現(xiàn)用戶登錄認(rèn)證詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07Python使用文件鎖實(shí)現(xiàn)進(jìn)程間同步功能【基于fcntl模塊】
這篇文章主要介紹了Python使用文件鎖實(shí)現(xiàn)進(jìn)程間同步功能,結(jié)合實(shí)例形式分析了Python基于fcntl模塊文件鎖功能實(shí)現(xiàn)進(jìn)程間同步的相關(guān)操作技巧,需要的朋友可以參考下2017-10-10在keras中獲取某一層上的feature map實(shí)例
今天小編就為大家分享一篇在keras中獲取某一層上的feature map實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-01-01pytest自動(dòng)化測(cè)試中的fixture的聲明和調(diào)用
這篇文章主要為大家介紹了pytest自動(dòng)化測(cè)試中的fixture的聲明和調(diào)用,文中含有詳細(xì)示例操作有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-10-10Python創(chuàng)建一個(gè)空的dataframe,并循環(huán)賦值的方法
今天小編就為大家分享一篇Python創(chuàng)建一個(gè)空的dataframe,并循環(huán)賦值的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-11-11python 實(shí)現(xiàn)刪除文件或文件夾實(shí)例詳解
這篇文章主要介紹了python 實(shí)現(xiàn)刪除文件或文件夾實(shí)例詳解的相關(guān)資料,這里附有實(shí)例代碼,需要的朋友可以參考下2016-12-12python末尾逗號(hào)導(dǎo)致返回結(jié)果是一個(gè)元組的問題
在Python中,除非特別需要返回或傳參元組,一般不推薦在語句末尾添加逗號(hào),應(yīng)該注意檢查是否存在末尾逗號(hào)導(dǎo)致的這些副作用,這篇文章主要介紹了python末尾逗號(hào)導(dǎo)致返回結(jié)果是一個(gè)元組,需要的朋友可以參考下2023-09-09