python 包之 re 正则匹配教程♀?♀一、开头匹配从字符串开头开始匹配返回匹配对象;如果找不到匹配,则为Noneimport reprint(re.match('飞兔小哥', '飞兔小哥教你零基础学编程'))print(re.match('学编程', '飞兔小哥教你零基础学编程'))二、全匹配匹配字符串是否和给定的字符一模一样如果一模一样才返回匹配对象,如果找不到匹配,则为Noneimport reprint(re.fullmatch('飞兔小哥教你零基础学编程', '飞兔小哥教你零基础学编程'))print(re.fullmatch('飞兔小哥', '飞兔小哥教你零基础学编程'))三、部分匹配只要在字符串中找到字符存在即可找到返回匹配对象,如果找不到匹配,则为Noneimport reprint(re.search('autofelix', '飞兔小哥教你零基础学编程'))print(re.search('飞兔小哥', '飞兔小哥教你零基础学编程'))四、匹配替换用正则表达式去匹配原始字符串,并把匹配到的内容替换import re# 去掉电话号码中的-num = re.sub(r'\D', '', '188-1926-8053')print(num)# 18819268053五、匹配替换返回数量用正则表达式去匹配原始字符串,并把匹配到的内容替换并且返回被替换掉的数量import re# 去掉电话号码中的-num = re.subn(r'\D', '', '188-1926-8053')print(num)# (18819268053, 2)六、分割字符串按照正则表达式的规则来分割字符串,并返回列表可以规定分割的次数import reprint(re.split('a*', 'hello world'))# ['', 'h', 'e', 'l', 'l', 'o', ' ', 'w', 'o', 'r', 'l', 'd', '']print(re.split('a*', 'hello world', 1))# ['', 'hello world']七、匹配所有在字符串中匹配所有符合正则表达式的对象并把这些对象通过列表list的形式返回import repattern = re.compile(r'\W+')result1 = pattern.findall('hello world!') result2 = pattern.findall('hello world!', 0, 7)print(result1)# [' ', '!']print(result2)# [' ']八、迭代器匹配在字符串中匹配所有符合正则表达式的对象并把这些对象通过迭代器的形式返回import repattern = re.compile(r'\W+') result = pattern.finditer('hello world!')for r in result: print(r)九、编译对象把正则表达式编译成Pattern对象import repattern = re.compile(r'\W+')十、修饰符re.I:忽略大小写re.L:本地化识别匹配re.M:多行匹配re.S:使.匹配包括换行在内的所有字符re.U:根据unicode字符解析字符re.X:给予灵活的格式以便理解import recontent = "Cats are smarter than dogs"print(re.search(r'DOGS', content, re.M | re.I))以上就是本次分享的全部内容,现在想要学习编程的小伙伴欢迎关注Python技术大本营,获取更多技能与教程。
