[py] 这正则为啥匹配失败? re.match(': (?P<to>\d+) ms', 'v2: 10000 ms')

2017-07-15 14:13:36 +08:00
 aheadlead

写了这么多年 python 了,今天遇到一个不太明白的问题。

问题就如标题(为了简短期间,标题里面稍作改动)。

这样死活匹配不出来:

>>> r = re.match(': (?P<timeout>\d+) ms', 'Screen off timeout: 10000 ms')
>>> r
>>> print(r)
None

改成这样就好了:

>>> r = re.match('Screen off timeout: (?P<timeout>\d+) ms', 'Screen off timeout: 10000 ms')
>>> r
<_sre.SRE_Match object; span=(0, 28), match='Screen off timeout: 10000 ms'>

求大虾指点其原理?在线跪等

2291 次点击
所在节点    程序员
4 条回复
hugo775128583
2017-07-15 14:17:24 +08:00
match 是从头开始匹配。
请用 search
aheadlead
2017-07-15 14:29:20 +08:00
@hugo775128583 学习了 谢谢
aheadlead
2017-07-15 14:33:09 +08:00
@hugo775128583
没想到这么多年我都是瞎用的,没好好看文档。 [面壁思过]

请教大虾,能否这样理解:
re.match(pattern, string) 等于 re.search('^' + patttern, string)
ipwx
2017-07-15 14:37:41 +08:00

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/375537

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX