gpt4 book ai didi

详解Python 最短匹配模式

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 25 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章详解Python 最短匹配模式由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

问题 。

你正在试着用正则表达式匹配某个文本模式,但是它找到的是模式的最长可能匹配。 而你想修改它变成查找最短的可能匹配.

解决方案 。

这个问题一般出现在需要匹配一对分隔符之间的文本的时候(比如引号包含的字符串)。 为了说明清楚,考虑如下的例子:

?
1
2
3
4
5
6
7
8
>>> str_pat = re. compile (r '"(.*)"' )
>>> text1 = 'Computer says "no."'
>>> str_pat.findall(text1)
[ 'no.' ]
>>> text2 = 'Computer says "no." Phone says "yes."'
>>> str_pat.findall(text2)
[ 'no." Phone says "yes.' ]
>>>

在这个例子中,模式 r'\"(.*)\"' 的意图是匹配被双引号包含的文本。 但是在正则表达式中*操作符是贪婪的,因此匹配操作会查找最长的可能匹配。 于是在第二个例子中搜索 text2 的时候返回结果并不是我们想要的.

为了修正这个问题,可以在模式中的*操作符后面加上?修饰符,就像这样:

?
1
2
3
4
>>> str_pat = re. compile (r '"(.*?)"' )
>>> str_pat.findall(text2)
[ 'no.' , 'yes.' ]
>>>

这样就使得匹配变成非贪婪模式,从而得到最短的匹配,也就是我们想要的结果.

讨论 。

这一节展示了在写包含点(.)字符的正则表达式的时候遇到的一些常见问题。 在一个模式字符串中,点(.)匹配除了换行外的任何字符。 然而,如果你将点(.)号放在开始与结束符(比如引号)之间的时候,那么匹配操作会查找符合模式的最长可能匹配。 这样通常会导致很多中间的被开始与结束符包含的文本被忽略掉,并最终被包含在匹配结果字符串中返回。 通过在 * 或者 + 这样的操作符后面添加一个 ? 可以强制匹配算法改成寻找最短的可能匹配.

以上就是详解Python 最短匹配模式的详细内容,更多关于Python 最短匹配模式的资料请关注我其它相关文章! 。

原文链接:https://python3-cookbook.readthedocs.io/zh_CN/latest/c02/p07_specify_regexp_for_shortest_match.html 。

最后此篇关于详解Python 最短匹配模式的文章就讲到这里了,如果你想了解更多关于详解Python 最短匹配模式的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com