python正则贪婪匹配
一、问题:
我想对a234ba444bab这个字符串,提取出来234和444两组数据,要怎么匹配
二、回答
采用re.findall('a(.+?)b','a234ba444bab')
说明:
这里.+代表起码匹配一个,如果用.* 的话可能匹配出来空即0~n个
这里?代表最小匹配即非贪婪匹配,上面的意思是当看到b就结束,不加?则看到b不会立马结束,还会继续往后查找直到找到最后一个b才结束
代码如下所示:
1 #默认贪婪匹配即最大匹配,?为非贪婪匹配即最小匹配 2 strData = "a234ba444bab" 3 print(re.findall('a(.+)b',strData)) 4 print(re.findall('a(.*)b',strData)) 5 6 print(re.findall('a(.+?)b',strData)) 7 print(re.findall('a(.*?)b',strData)) 8 9 >>> 运行结果如下: 10 >>> ['234ba444ba'] 11 >>> ['234ba444ba'] 12 >>> ['234', '444'] 13 >>> ['234', '444', '']
可以看到想要实现问题中的结果,正确答案是第三种第6行的写法:print(re.findall('a(.+?)b',strData))
分类:
07-python3核心技术
标签:
贪婪匹配
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!