正则表达式讲解(详细备注)

import re
res = re.match("^lei\d+","lei123 wodeshebao") #
print("输出结果为1:",res.group()) #输出结果为: lei123
# . 默认匹配除\n之外的任意一个字符,若指定flag DOTALL,则匹配任意字符,包括换行
res1 = re.match(".","\nlei123 wodeshebao",flags=re.DOTALL)
print("输出结果为2:",res1.group()) #输出结果为:
res2 = re.match(".","lei123 wodeshebao")
print("输出结果为3:",res2.group())

输出结果为:

在这里插入图片描述

# ^ 匹配字符串开头,若指定flags MULTILINE,这种也可以匹配上
res3 = re.match("^ab","abc\nleizi",flags=re.MULTILINE)
print(res3.group()) #ab
# $ 匹配字符串结尾
res4 = re.search("wo$","Iwo\nsadif",flags=re.MULTILINE).group()
print(res4) #wo
# * 匹配*号前的字符串0次或多次
res5 = re.findall("abc*","abcccsd ab9ji abc4dghf")
print(res5) #['abccc', 'ab', 'abc']
# + 匹配前一个字符1次或多次
res6 = re.findall("ab+","abbhiiog abjii ajf")
print(res6) #['abb', 'ab']
# ? 匹配前一个字符1次或0次
res7 = re.findall("ab?","ajjf abjjk abbc")
print(res7) #['a', 'ab', 'ab']
# {m} 匹配前一个字符m次
res8 = re.search(r"ab{3}","abbbm ababbbnn abcm am").group()
print(res8) #abbb
# (...) 分组匹配
res9 = re.search("(abc){2}ad(12|34)c","abcabcad34c").group()
print(res9) #abcabcad34c
# \A 只从字符串开头匹配
str1 = re.search("\Aabc","abclexabc")
print(str1) #<re.Match object; span=(0, 3), match='abc'>
# \z 匹配字符串结尾,同$
str2 = re.search("ab$","abvfggab").group()
print(str2) #ab
# \d 匹配数字0-9
str3 = re.search("\d","wefftg3kkgh2")
print(str3) #<re.Match object; span=(6, 7), match='3'>
# \D 匹配非数字
str4 = re.search("\D+","ashj12234fd2345").group()
print(str4) #ashj
# \w 匹配[A-Za-z0-9]
str5 = re.search("\w+","D98asji&@jgif87").group()
print(str5) #D98asji
# \W 匹配非[A-Za-z0-9]
str6 = re.search("\W+","D98asji&@jgif87").group()
print(str6) #&@
# s 匹配空白字符、\t,\r
str7 = re.search("\s+","ab\tdd\noi").group()
print(str7,"前面是匹配结果") #	 前面是匹配结果

re–groupdict用法、split用法、sub替换用法

#第一种写法
result = re.search("(?P<id>[0-9]+)(?P<name>[a-zA-Z]+)","abc123leiyu@12345").groupdict()
print(result) #{'id': '123', 'name': 'l'}
print(result["id"]) #123
#第二种写法
result1 = re.search("(?P<id>[0-9]+)(?P<name>[a-zA-Z]+)","abc123leiyu@12345").group("name")
print(result1) #leiyu
#匹配身份证中的省市县和生日
result2 = re.search("(?P<province>[0-9]{3})(?P<city>[0-9]{3})(?P<birthday>[0-9]{4})","410423199909264687").groupdict()
print(result2) #{'province': '410', 'city': '423', 'birthday': '1999'}

#split的用法,解释将字符串按特定的要求进行分割
result3 = re.split("[0-9]","wo12de3she678bao")
print(result3) #['wo', '', 'de', 'she', '', '', 'bao']
result4 = re.split("[0-9]+","wo12de3she678bao")
print(result4) #['wo', 'de', 'she', 'bao']

#sub的用法,sub(pattern,repl,string,count=0,flags=0)
#其中pattern需要填写的正则表达式,repl表示替换的值,string匹配的字符串,count替换的地方个数
result6 = re.sub("[0-9]+","=","wq12hgh8mmww56ssaa")
print(result6) #wq=hgh=mmww=ssaa
result7 = re.sub("[0-9]+","=","wq12hgh8mmww56ssaa",count=2)
print(result7) #wq=hgh=mmww56ssaa

反斜杠匹配

#正则中反斜杠的匹配,需要4个反斜杠
result8 = re.search("\\\\","wq12hg\h8mmww56ssaa").group()
print(result8) #\

flags的用法

#flags的用法,IGNORECASE忽略大小写-写法为re.I、MULTILINE匹配多行模式-写法为re.M、DOTALL点任意匹配模式-写法为re.S
num2 = re.search("[a-z]+","asDjWnQ").group()
print("添加flags前结果",num2) #添加flags前结果 as
num1 = re.search("[a-z]+","asDjWnQ",flags=re.I).group()
print("添加flags后结果",num1) #添加flags后结果 asDjWnQ
#匹配多行模式
num3 = re.search("^a","\nasd23",flags=re.M).group()
print(num3) #a
num4 = re.search("^a","\nasd23").group()
print(num4) #程序报错
#匹配任意字符re.S
num5 = re.search("^.+","\nabc\nhgf").group()
print(num5) #程序报错
num6 = re.search("^.+","\nabc\nhgf",flags=re.S).group()
print(num6) #abc
            #hgf

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值