python正则re
2024-09-02 17:37:54
import re
line = "Catsaresmarterthandogs"
matchObj = re.match( r'(.*)are(\w{2})(.*)', line, re.M|re.I)
if matchObj:
print ("matchObj.group() : ", matchObj.group())#group返回匹配的整个字符串,groups返回匹配各分组的元祖
print ("matchObj.group(1) : ", matchObj.group(1))#span(1)返回匹配第一个分组的起始索引
print ("matchObj.group(2) : ", matchObj.group(2))
print ("matchObj.group(2) : ", matchObj.group(3))
else:
print ("No match!!")
matchObj.group() : Catsaresmarterthandogs
matchObj.group(1) : Cats
matchObj.group(2) : sm
matchObj.group(2) : arterthandogs
search用法一样
————————————————————————————————————————————————————————————————————————————
re.match只匹配字符串的开始,如果字符串开始不符合正则表达式,则匹配失败,函数返回None;
而re.search匹配整个字符串,直到找到一个匹配。match 和 search 是匹配一次 findall 匹配所有
num = re.sub(r'#.*$', "", str) re.sub(替换规则,替换成xx,操作的字符串);用于替换字符串中的匹配项 ——————————————————————————————————————————————————————————————
# 将匹配的数字乘以 2
import re
# 将匹配的数字乘以 2
def double(matched):
value = int(matched.group('value'))
return str(value * 2)
s = 'A23G4HFD567'
print(re.sub('(?P<value>\d+)', double, s))#A46G8HFD1134
——————————————————————————————————————————————————————————————————
re.finditer(r"\d+","12a32bc43jf3") 返回匹配结果为一个迭代器
re.split('\W+', 'w3cschool, w3cschool, w3cschool.')分割匹配结果为一个列表
————————————————————————————————————
[^...] [^abc] 匹配除了a,b,c之外的字符[^0-9] 匹配除了数字外的字符
最新文章
- HTML 网页特效CSS大全
- Github上传自己的工程
- Memcache安全配置
- Codeforces Round #278 (Div. 1) B. Strip multiset维护DP
- LogBack入数据库重写
- Memcached Java Client with sample program--reference
- shell提示符显示git当前分支
- Android开发之自定义Spinner样式的效果实现(源代码实现)
- Mysql insert声明优化
- c# winfrom DataGridView使行高不可改变,使列头高度不可改变,
- Linux 字符驱动程序(一)
- 北京南天软件java工程师面试题
- 团队作业4----第一次项目冲刺(Alpha版本)4.24
- [国嵌攻略][159][SPI子系统]
- epoll函数
- 上传前端webuploader
- Java基础——Oracle(六)
- c++拷贝构造函数(深拷贝、浅拷贝)——转
- TF400511: Your team has not defined any iterations to use as sprints
- docker探索-swarm搭建docker集群(七)