麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > regex > 正文

python正則表達式的使用(實驗代碼)

2020-01-20 21:34:17
字體:
來源:轉載
供稿:網友

正則表達式是一個特殊的字符序列,它能幫助你方便的檢查一個字符串是否與某種模式匹配。
Python 自1.5版本起增加了re 模塊,它提供 Perl 風格的正則表達式模式。
re 模塊使 Python 語言擁有全部的正則表達式功能。
compile 函數根據一個模式字符串和可選的標志參數生成一個正則表達式對象。該對象擁有一系列方法用于正則表達式匹配和替換。

re 模塊也提供了與這些方法功能完全一致的函數,這些函數使用一個模式字符串做為它們的第一個參數。

python正則表達式的使用(實驗代碼),具體代碼如下所示:

import redata='''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)非編譯正則表達式的使用def re_nocompile(): pattern="report" #匹配時間格式 r=re.findall(pattern,data,flags=re.IGNORECASE) # findall方法 返回字符串 print(r)# 1.2) 編譯的正則表達式的使用(效率高)def re_compile(): pattern = "[0-9]{1,2}/:[0-9]{1,2}/:[0-9]{1,2}" # 匹配時間格式 re_obj=re.compile(pattern) #創建一個對象 r=re_obj.findall(data) # findall方法 返回字符串 print(r)# 2.1)“匹配” 類函數的使用 findall、 match、search、finditerdef re_match(): pattern = "/d+" # 匹配數字 r=re.match(pattern,data) #match 函數是匹配字符串的開頭,類似startwith if r:  # 使用match匹配成功后,返回SRE_MATCH類型的對象,該對象包含了相關模式和原始字符串,包括起始位置和結束位置  print(r)  print(r.start())  print(r.end())  print(r.string)  print(r.group()) # group()用來提出分組截獲的字符串。group() 同group(0)就是匹配正則表達式整體結果。  # group(1) 列出第一個括號匹配部分,group(2) 列出第二個括號匹配部分,group(3) 列出第三個括號匹配部分。  # 當然正則表達式中沒有括號,group(1)肯定不對了  print(r.re) else: # match如果匹配不到,返回None  print("False")def re_search(): pattern = "[0-9]{1,2}/:[0-9]{1,2}/:[0-9]{1,2}" # 匹配時間格式 r=re.search(pattern,data) # search方法是全部位置的匹配,返回SRE_MATCH對象 print(r) print(r.start()) #起始位置 print(r.end()) #結束位置 # finditer返回一個迭代器def re_finditer(): pattern = "/d+" # 匹配數字 r=re.finditer(pattern,data) for i in r:  print(i.group())# 貪婪匹配:總是匹配最長的那個字符串(默認)# 非貪婪匹配:總是匹配最短的那個字符串(在匹配字符串時加上?來實現)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 reimport requestsdata='''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.1) sub函數進行匹配并替換,返回替換后的字符串def re_sub(): pattern = "[0-9]{1,2}/:[0-9]{1,2}/:[0-9]{1,2}" # 匹配時間格式 data01=re.sub(pattern,"timeString",data) print(data01)# 1.2)splite將字符串拆成子串列表,可以同時指定多個分隔符def re_split(): r=re.split(r"[:/-/=]",data.strip("'")) print(r)# 2)匹配html的一個例子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()

總結

以上所述是小編給大家介紹的python正則表達式的使用(實驗代碼),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 毛片在线免费观看网址 | 深夜免费观看视频 | 国产亚洲精品久久午夜玫瑰园 | 欧美亚州 | 久草最新网址 | 孕妇体内谢精满日本电影 | 国产成人精品区 | 免费一级欧美在线观看视频 | 最新亚洲国产 | 91精品国产福利尤物免费 | 久久精品亚洲国产奇米99 | 国产午夜精品理论片a级探花 | 国产高潮失禁喷水爽到抽搐视频 | 手机黄色小视频 | 国产精品视频一区二区三区四 | 亚洲精品无码不卡在线播放he | 久久久婷婷 | 亚洲午夜天堂吃瓜在线 | 免费一级a毛片免费观看 | 亚洲国产小视频 | 国产免费一区二区三区网站免费 | 国产精品一区二区x88av | 91精品国产福利尤物免费 | 国产一区二区精品在线观看 | 播色网 | 国产精品久久久久久久久久久久久久久久 | 欧美a区| 欧美成人精品欧美一级乱黄 | 日本a∨精品中文字幕在线 被啪羞羞视频在线观看 | 久久久久一区二区三区 | av日韩在线免费观看 | 国产精品色综合 | 国产成人精品一区二区视频免费 | 国产亚洲精品久久 | 久国产| 人禽l交免费视频 | 国产亚洲精品成人a | 成熟女人特级毛片www免费 | 国产一级一片免费播放 | 久久久精品视频在线观看 | 欧美性受xxxx人人本视频 |