正则表达式,首先找到 – Python

前端之家收集整理的这篇文章主要介绍了正则表达式,首先找到 – Python前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
i="<wx._controls.Button; proxy of <Swig Object of type 'wxButton *' at 0x2887828> >]],[[[41,183],'Button',<wx._controls.Button; proxy of <Swig Object of type 'wxButton *' at 0x28879d0> >]]]"

m = re.findall("<wx.(.*)> >",i)

会给我的

["<wx._controls.Button; proxy of <Swig Object of type 'wxButton *' at 0x2887828> >]],<wx._controls.Button; proxy of <Swig Object of type 'wxButton *' at 0x28879d0> >"]

不过我想要它给我,

["<wx._controls.Button; proxy of <Swig Object of type 'wxButton *' at 0x2887828> >","<wx._controls.Button; proxy of <Swig Object of type 'wxButton *' at 0x28879d0> >"]

正则表达式一直在搜索直到结束,我想把所有与正则表达式匹配的部分拿出来,有没有人知道这个的解决方案?

解决方法

*运算符默认是贪心的.你可以通过添加一个来改变它吗?在它之后.还记得引用字面点.

我也使组不匹配,否则你不会得到所需的输出(这似乎是你的原始代码的问题):

re.findall(r"<wx\.(?:.*?)> >",i)

另一种可能性如下(假设一个<字符在第一个>之前出现),这比具有lazy *运算符的版本更快:

re.findall(r"<wx\.[^<]*<[^<]*> >",i)

猜你在找的正则表达式相关文章