正则表达式是一个特殊的字符序列,它能帮助你方便的检查一个字符串是否与某种模式匹配。这篇文章主要介绍了python正则表达式的使用(实验代码),非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧

正则表达式是一个特殊的字符序列,它能帮助你方便的检查一个字符串是否与某种模式匹配。
Python 自1.5版本起增加了re 模块,它提供 Perl 风格的正则表达式模式。
re 模块使 Python 语言拥有全部的正则表达式功能。
compile 函数根据一个模式字符串和可选的标志参数生成一个正则表达式对象。该对象拥有一系列方法用于正则表达式匹配和替换。

广东11选五5re 模块也提供了与这些方法功能完全一致的函数,这些函数使用一个模式字符串做为它们的第一个参数。

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("http://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正则表达式的使用(实验代码),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对爱安网网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

最新资讯
菜鸟:向快递员致敬 将群体发布春节补贴

菜鸟:向快递员致敬 将

申通副总裁今日在朋友圈发布消息称,“疫情当头,快递员依
马云公益基金会捐赠一亿元用于支持冠状病毒疫苗研发

马云公益基金会捐赠一

马云公益基金会今天宣布,捐赠一亿元人民币用于支持冠状
助力抗击疫情!网易追加捐赠1亿元 设专项防控基金

助力抗击疫情!网易追加

网易公司宣布追加捐赠1亿元人民币,设立新型冠状病毒疫
抗击疫情 盛趣游戏母公司世纪华通捐款1000万元

抗击疫情 盛趣游戏母

为支持当前坚守在疫情一线的医护及其他工作者,世纪华通
富士康:疫情不会影响苹果订单的完成 已有后备方案

富士康:疫情不会影响苹

富士康周二表示,可以确认我们已经采取措施确保我们能够
浙大联合拼多多共同设立防控基金 规模达1亿元

浙大联合拼多多共同设

浙江大学宣布,联合上海寻梦信息技术有限公司成立浙江大
最新文章
JS正则(RegExp)判断文本框中是否包含特殊符号

JS正则(RegExp)判断文

这篇文章主要介绍了JS正则(RegExp)判断文本框中是否包
解决正则表示式匹配($regex)引起的一次mongo数据库cpu占用率高的问题

解决正则表示式匹配($

这篇文章主要介绍了由正则表示式匹配($regex)引起的一
pycharm使用正则表达式批量添加print括号完美从python2迁移到python3

pycharm使用正则表达

这篇文章主要介绍了pycharm中使用正则表达式批量添加p
2019年前端必用js正则(小结)

2019年前端必用js正则

这篇文章主要介绍了2019年前端必用js正则,文中通过示例
循序渐进掌握递归正则表达式【推荐】

循序渐进掌握递归正则

这篇文章主要介绍了循序渐进掌握递归正则表达式的相关
正则表达式的使用规则

正则表达式的使用规则

正则表达式通常被用来检索、替换那些符合某个模式(规