正则表达式很神奇啊
# -*- coding:utf-8 -*- import re def print_match_res(res): """打印匹配对象内容""" if res is not None: print(res.group()) else: print(None) # 两种匹配方式: pattern="[A-Z][a-z]+" # 一、使用re模块函数进行匹配 res=re.match(pattern,"Tom is a good boy") # 匹配,返回匹配对象 print(type(res)) print(res.group()) # 二、使用预编译后的正则表达式对象的方法进行匹配 obj_pattern=re.compile(pattern) # 预编译,返回正则表达式对象 print(type(obj_pattern)) res=obj_pattern.match("Tom is a good boy") # 匹配,返回匹配对象 print(type(res)) print(res.group()) # 匹配对象的group()和groups()方法 pattern="\d{3}-\d{5}" obj_pattern=re.compile(pattern) res=obj_pattern.search("家庭电话:000-88886") print(res.group()) # 返回整个匹配或特定子组 print(res.groups()) # 返回包含全部子组的元组 # match():从起始部分开始匹配,如果成功,返回匹配对象;失败,返回None。只匹配一次 pattern="my" # res=re.compile(pattern).match("my name is li") res=re.match(pattern,"my name is li") print_match_res(res) # search(): 从任意位置开始匹配,如果成功,返回匹配对象;失败,返回None。只匹配一次 pattern="my" # res=re.compile(pattern).search("it's my dog") res=re.search(pattern,"my name is li") print_match_res(res) # 查找全部 # findall(),finditer() res=re.findall(r"th\w+","This and that",re.I) print(res) res=re.finditer(r"th\w+","This and that",re.I) print(res) print(next(res).group(),next(res).group()) # 替换 # sub(),subn() res=re.sub("funny","fool","You are so funny") print(res) res=re.subn("funny","fool","You are so funny") print(res) # 分割 # splite() res=re.split("\.","Mr.Smith") print(res) print("#"*50) # 择一匹配符号 a|b pattern="I|You|She" res=re.compile(pattern,flags=re.IGNORECASE).match("i love you") print_match_res(res) res=re.compile(pattern,flags=re.I).search("who love you") print_match_res(res) # 匹配任意单个字符 . pattern="w{3,}\..+\.com" res=re.match(pattern,"wwww.google.com/index.html",re.I) print_match_res(res) # 字符集 [abc] [a-z0-9] pattern="[A-Za-z0-9_]*\." res=re.match(pattern,"Python3.") print_match_res(res) # 特殊字符 \d \w \s \b \# 重复 + "\w+@(\w{1,10}\.)*([a-z]*)" res=re.match(pattern,"li@gmail.com") print_match_res(res) res=re.match(pattern,"li@qq.vip.org") print_match_res(res) print(res.group(0),res.group(1),res.group(2),sep="\t") print(res.groups()) # 匹配字符串的起始和结尾,单词边界 ^a z$ \A \Z \b \B pattern=r"^the" # pattern=r"\Athe" res=re.search(pattern,"The end of the world") print_match_res(res) res=re.search(pattern,"they smile") print_match_res(res) pattern=r"cry$" # pattern=r"cry\Z" res=re.search(pattern,"they cry") print_match_res(res) res=re.search(r"\bthe","bit the dog") print_match_res(res) res=re.search(r"\Bhe","bit the dog") print_match_res(res)
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com
暂无“Python中正则表达式的用法总结”评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2025年04月26日
2025年04月26日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]