python表达式实验_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正则表达式的使用(实验代码),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Python 爬虫中,正则表达式是非常常用的技术,可以帮助我们从网页中提取出需要的信息。下面是一些常用的正则表达式符号和方法: 1. ".":匹配任意单个字符,除了换行符。 2. "^":匹配字符串的开始位置。 3. "$":匹配字符串的结束位置。 4. "*":匹配前一个字符出现 0 次或多次。 5. "+":匹配前一个字符出现 1 次或多次。 6. "?":匹配前一个字符出现 0 次或 1 次。 7. "{m}":匹配前一个字符出现 m 次。 8. "{m,n}":匹配前一个字符出现 m 到 n 次。 9. "(...)":分组匹配,匹配括号内的表达式。 10. "[...]":匹配括号内的任意一个字符。 11. "[^...]":匹配不在括号内的任意一个字符。 12. "\d":匹配数字,等同于 [0-9]。 13. "\D":匹配非数字,等同于 [^0-9]。 14. "\s":匹配空白字符,包括空格、制表符、换行符等。 15. "\S":匹配非空白字符。 16. "\w":匹配单词字符,包括字母、数字、下划线。 17. "\W":匹配非单词字符。 在 Python 中,使用 re 模块进行正则表达式的匹配。常用的方法包括: 1. re.compile(pattern):将正则表达式编译成一个对象,提高匹配效率。 2. re.search(pattern, string):在字符串中搜索匹配正则表达式的第一个位置。 3. re.findall(pattern, string):在字符串中搜索匹配正则表达式的所有位置,并返回一个列表。 4. re.sub(pattern, repl, string):将字符串中所有匹配正则表达式的字符替换为指定的字符串。 以上是一些常用的正则表达式符号和方法,希望能对你有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值