Python正则匹配结果不符:分组非贪婪匹配为何少匹配字符?
python 正则匹配存在差异的原因
使用分组非贪婪匹配进行正则表达式的匹配时,发现匹配结果与预期不符,少了 7 个字符。通过仔细观察发现,问题出现在匹配模式中。
正则表达式中的 .(点)表示匹配任意单个字符。在这种情况下,作者希望匹配像 forum/w33d580/ 这样的路径部分。然而,代码中使用了 r'http://tiebapic.baidu.com/(.+?)sign=.+?/(.+?).(.+?)' 模式,这里 .+? 匹配到的是任意数量的任意字符,包括 t 字符。
因此,匹配结果中缺少了最后的 .jpg,因为它被 t 字符替换掉了。为了解决此问题,需要转义点,即使用 . 替换 .。
立即学习“Python免费学习笔记(深入)”;
修改后的正则表达式:
pattern = re.compile(r'http://tiebapic.baidu.com/(.+?)sign=.+?/(.+).(.+?)?tbpicau=', re.s)
现在,匹配结果将是预期的:
forum/w33D580/9728d9177f3e67097e8a81c87dc79f3df9dc55aa.jpg
文章推荐
-
Python实现字典的key和values的交换
有些时候我们不得已要利用values来反向查询key,有没有简单的方法呢?下面我给大家列举一些方法,方便大家使用pyth...
Python
3周前 (02-11) 126 -
使用Python脚本来获取Cisco设备信息的示例
今天发现一个使用python写的管理cisco设备的小框架tratto,可以用来批量执行命令。下载后主要有3个文件:Sy...
Python
3周前 (02-11) 76 -
Python的Django中django-userena组件的简单使用教程
利用twitter/bootstrap,项目的基础模板算是顺利搞定。接下来开始处理用户中心。用户中心主要包括用户登陆、注...
Python
3周前 (02-11) 67 -
零基础写python爬虫之神器正则表达式
接下来准备用糗百做一个爬虫的小例子。但是在这之前,先详细的整理一下Python中的正则表达式的相关内容。正则表达式在Py...
Python
3周前 (02-11) 75 -
零基础写python爬虫之抓取百度贴吧代码分享
这里就不给大家废话了,直接上代码,代码的解释都在注释里面,看不懂的也别来问我,好好学学基础知识去! 代码如下:# -*-...
Python
3周前 (02-11) 66
最新文章
- Python实现字典的key和values的交换 3周前 (02-11)
- 使用Python脚本来获取Cisco设备信息的示例 3周前 (02-11)
- Python的Django中django-userena组件的简单使用教程 3周前 (02-11)
- 零基础写python爬虫之神器正则表达式 3周前 (02-11)
- 零基础写python爬虫之抓取百度贴吧代码分享 3周前 (02-11)
- 零基础写python爬虫之使用urllib2组件抓取网页内容 3周前 (02-11)
- 在Docker上部署Python的Flask框架的教程 3周前 (02-11)
- 简单说明Python中的装饰器的用法 3周前 (02-11)
- 利用Python实现简单的相似图片搜索的教程 3周前 (02-11)
- 在Python中使用模块的教程 3周前 (02-11)