python中正则表达式基本应用

python中正则表达式基本应用

基本应用

import re 
match_re = re.match(".*?(\d+).*", str_value)
if match_re:
    data = match_re.group(1)

在线正则表达式测试

在线正则表达式测试网页

re模块

  1. re.match(pattern,string, flags=0)
    1)简述:从第一个字符开始搜索,如果如果第一个不匹配则返回none,所以必须指定正则表达式打头信息。
content = “Hello 1234567 World. This is a Reges Demo”
2)匹配
result = re.match(“”,content,)
data = result.group() #返回匹配的对象
location = result.span() #返回匹配的内容在文本中的位置
3)泛匹配——.*(匹配任意多个字符)
data = result.match(“Hello.*Demo”,content)
4)匹配指定目标
括号内的正则表达式为指定的匹配目标,返回结果通过data.group()或data.groups()函数获得。
result = re.match(“Hello\s(\d+)\sWorld.*Demo$”,content)
# 括号括起来为匹配组,从1开始计数。
data = result.group(1)
5)贪婪匹配
result = re.match(“He.*(\d+).*Demo$”,content)
print(result.group(1))
# 输出:7
# 因为这样的正则表达式默认为贪婪匹配,.*会尽可能多的匹配字符,所以.*匹配了7以前的全部字符。
6)非贪婪匹配
result = re.match(“He.*?(\d+).*Demo$”,content)
# 输出:1234567
# 因为在.*后面加了?,匹配模式变成了非贪婪模式匹配,.*会匹配尽可能少的字符。
7)匹配模式
result = re.match(“”,content, re.S)
# re.S模式:设置后可以使.匹配到换行符
8)转义
转义通过‘\’实现,例如字符串中原本就存在.这样的字符,但是它并不是正则表达式,则在写成‘\.’即可表示字符‘.'的含义。
  1. re.search()
    整个扫描文本,找到第一个匹配的项,返回结果。所以一般常用re.search()方法做正则匹配。
content = “Extra HEllo 123456 World. This is a Regex Demo Extra stings”
result = re.search(“Hello.*?(\d+).*?Demo”, content)
  1. re.findall()
    查询符合条件的所有结果。返回列表类型,列表元素为元组。
  2. re.sub()
    替换字符串中的每一个匹配的字串后返回替换后的字符串。
    参数:正则表达式,要替换的字符串,源字符串
  3. re.complie()
    将正则表达式编译成正则表达式对象
pattern =re.complie(“”, re.S)
result =re.match(pattern, content)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值