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

溫馨提示×

溫馨提示×

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

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

怎樣在python中使用正則表達式

發布時間:2021-06-08 16:32:31 來源:億速云 閱讀:166 作者:Leah 欄目:互聯網科技

本篇文章為大家展示了怎樣在python中使用正則表達式,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

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

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

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

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)非編譯正則表達式的使用
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、finditer
def 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 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)“修改類”函數
# 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中使用正則表達式,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

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

AI

无为县| 遂平县| 南皮县| 鄂托克前旗| 武定县| 岑巩县| 互助| 永福县| 泰顺县| 临澧县| 建昌县| 阳信县| 唐河县| 新兴县| 青铜峡市| 浪卡子县| 朔州市| 象山县| 南川市| 邳州市| 凌云县| 秦安县| 吉木乃县| 塘沽区| 二连浩特市| 远安县| 威远县| 保靖县| 临朐县| 大连市| 永善县| 汨罗市| 桦甸市| 辛集市| 沾益县| 栾川县| 浑源县| 岳阳县| 且末县| 宁国市| 延川县|