python正則表達(dá)式的使用(實(shí)驗(yàn)代碼)
正則表達(dá)式是一個(gè)特殊的字符序列,它能幫助你方便的檢查一個(gè)字符串是否與某種模式匹配。
Python 自1.5版本起增加了re 模塊,它提供 Perl 風(fēng)格的正則表達(dá)式模式。
re 模塊使 Python 語(yǔ)言擁有全部的正則表達(dá)式功能。
compile 函數(shù)根據(jù)一個(gè)模式字符串和可選的標(biāo)志參數(shù)生成一個(gè)正則表達(dá)式對(duì)象。該對(duì)象擁有一系列方法用于正則表達(dá)式匹配和替換。
re 模塊也提供了與這些方法功能完全一致的函數(shù),這些函數(shù)使用一個(gè)模式字符串做為它們的第一個(gè)參數(shù)。
python正則表達(dá)式的使用(實(shí)驗(yàn)代碼),具體代碼如下所示:
import re
data='''12345 2019-05-20 13:30:04,102 E:/PythonProject/accountReport-20190520/createReport_20190520.py(164): [INFO]start=24h-ago&m=sum:zscore.keys{compared=week,redis=6380,endpoint=192.168.8.11_Redis-b}
2019-05-20 13:30:04,133 E:/PythonProject/accountReport-20190520/createReport_20190520.py(164): [INFO]start=24h-ago&m=sum:keys{redis=6380,endpoint=192.168.8.120_Redis-sac-a}
'''
# 1.1)非編譯正則表達(dá)式的使用
def re_nocompile():
pattern="report" #匹配時(shí)間格式
r=re.findall(pattern,data,flags=re.IGNORECASE) # findall方法 返回字符串
print(r)
# 1.2) 編譯的正則表達(dá)式的使用(效率高)
def re_compile():
pattern = "[0-9]{1,2}\:[0-9]{1,2}\:[0-9]{1,2}" # 匹配時(shí)間格式
re_obj=re.compile(pattern) #創(chuàng)建一個(gè)對(duì)象
r=re_obj.findall(data) # findall方法 返回字符串
print(r)
# 2.1)“匹配” 類(lèi)函數(shù)的使用 findall、 match、search、finditer
def re_match():
pattern = "\d+" # 匹配數(shù)字
r=re.match(pattern,data) #match 函數(shù)是匹配字符串的開(kāi)頭,類(lèi)似startwith
if r: # 使用match匹配成功后,返回SRE_MATCH類(lèi)型的對(duì)象,該對(duì)象包含了相關(guān)模式和原始字符串,包括起始位置和結(jié)束位置
print(r)
print(r.start())
print(r.end())
print(r.string)
print(r.group()) # group()用來(lái)提出分組截獲的字符串。group() 同group(0)就是匹配正則表達(dá)式整體結(jié)果。
# group(1) 列出第一個(gè)括號(hào)匹配部分,group(2) 列出第二個(gè)括號(hào)匹配部分,group(3) 列出第三個(gè)括號(hào)匹配部分。
# 當(dāng)然正則表達(dá)式中沒(méi)有括號(hào),group(1)肯定不對(duì)了
print(r.re)
else: # match如果匹配不到,返回None
print("False")
def re_search():
pattern = "[0-9]{1,2}\:[0-9]{1,2}\:[0-9]{1,2}" # 匹配時(shí)間格式
r=re.search(pattern,data) # search方法是全部位置的匹配,返回SRE_MATCH對(duì)象
print(r)
print(r.start()) #起始位置
print(r.end()) #結(jié)束位置
# finditer返回一個(gè)迭代器
def re_finditer():
pattern = "\d+" # 匹配數(shù)字
r=re.finditer(pattern,data)
for i in r:
print(i.group())
# 貪婪匹配:總是匹配最長(zhǎng)的那個(gè)字符串(默認(rèn))
# 非貪婪匹配:總是匹配最短的那個(gè)字符串(在匹配字符串時(shí)加上?來(lái)實(shí)現(xiàn))
def re_find02():
r1=re.findall("Python.*\.",data) # 貪婪匹配
print(r1)
r2 = re.findall("Python.*?\.", data) #非貪婪匹配
print(r2)
if __name__=="__main__":
re_nocompile()
re_compile()
re_match()
re_search()
re_finditer()
re_find02()
import re
import requests
data='''12345 2019-05-20 13:30:04,102 E:/PythonProject/accountReport-20190520/createReport_20190520.py(164): [INFO]start=24h-ago&m=sum:zscore.keys{compared=week,redis=6380,endpoint=192.168.8.11_Redis-b}
2019-05-20 13:30:04,133 E:/PythonProject/accountReport-20190520/createReport_20190520.py(164): [INFO]start=24h-ago&m=sum:keys{redis=6380,endpoint=192.168.8.120_Redis-sac-a}
'''
# 1)“修改類(lèi)”函數(shù)
# 1.1) sub函數(shù)進(jìn)行匹配并替換,返回替換后的字符串
def re_sub():
pattern = "[0-9]{1,2}\:[0-9]{1,2}\:[0-9]{1,2}" # 匹配時(shí)間格式
data01=re.sub(pattern,"timeString",data)
print(data01)
# 1.2)splite將字符串拆成子串列表,可以同時(shí)指定多個(gè)分隔符
def re_split():
r=re.split(r"[:\-\=]",data.strip("'"))
print(r)
# 2)匹配html的一個(gè)例子
def re_html():
r=requests.get("https://www.hao123.com/")
print(r.content)
try:
web=re.findall("(https:.*?.com)",str(r.content))
print(web)
except Exception as err:
print(err)
if __name__=="__main__":
re_sub()
re_split()
re_html()
總結(jié)
以上所述是小編給大家介紹的python正則表達(dá)式的使用(實(shí)驗(yàn)代碼),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)我們網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
上一篇:Python使用正則表達(dá)式分割字符串的實(shí)現(xiàn)方法
欄 目:正則表達(dá)式
下一篇:Python 正則表達(dá)式匹配數(shù)字及字符串中的純數(shù)字
本文標(biāo)題:python正則表達(dá)式的使用(實(shí)驗(yàn)代碼)
本文地址:http://www.jygsgssxh.com/a1/zhengzebiaodashi/11146.html
您可能感興趣的文章
- 01-11正則表達(dá)式實(shí)現(xiàn)添加、刪除、替換三種功能
- 01-11python 用正則表達(dá)式篩選文本信息的實(shí)例
- 01-11正則表達(dá)式之匹配數(shù)字范圍
- 01-11python爬蟲(chóng)正則表達(dá)式之處理?yè)Q行符
- 01-11正則表達(dá)式匹配路由的實(shí)現(xiàn)代碼
- 01-11正則表達(dá)式截取身份證號(hào)碼加密的方法
- 01-11js正則表達(dá)式 匹配兩個(gè)特定字符間的內(nèi)容示例
- 01-11MySQL使用正則表達(dá)式進(jìn)行查詢操作經(jīng)典實(shí)例總結(jié)
- 01-11python正則表達(dá)式之對(duì)號(hào)入座篇
- 01-11詳解正則表達(dá)式實(shí)現(xiàn)二代身份證號(hào)碼驗(yàn)證


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-11正則表達(dá)式實(shí)現(xiàn)添加、刪除、替換三
- 01-11正則表達(dá)式之匹配數(shù)字范圍
- 01-11python 用正則表達(dá)式篩選文本信息的實(shí)
- 01-11正則表達(dá)式匹配路由的實(shí)現(xiàn)代碼
- 01-11python爬蟲(chóng)正則表達(dá)式之處理?yè)Q行符
- 01-11js正則表達(dá)式 匹配兩個(gè)特定字符間的
- 01-11正則表達(dá)式截取身份證號(hào)碼加密的方
- 01-11python正則表達(dá)式之對(duì)號(hào)入座篇
- 01-11MySQL使用正則表達(dá)式進(jìn)行查詢操作經(jīng)典
- 01-11詳解正則表達(dá)式實(shí)現(xiàn)二代身份證號(hào)碼
隨機(jī)閱讀
- 01-11Mac OSX 打開(kāi)原生自帶讀寫(xiě)NTFS功能(圖文
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-10C#中split用法實(shí)例總結(jié)
- 04-02jquery與jsp,用jquery
- 01-10delphi制作wav文件的方法
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載


