鱼C论坛

 找回密码
 立即注册
查看: 3263|回复: 5

正则表达式匹配问题

[复制链接]
发表于 2017-7-2 22:17:52 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
想求教一个正则表达式的匹配问题

url = '<span>"|</span><a target="_blank" >帮助</a>'

res = re.findall('>(.*?)</a>',url)
for each in res:
    print each

为啥匹配出来的是一长串而不是帮助,.*?不是非贪婪匹配么?
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2017-7-2 22:56:01 | 显示全部楼层
res = re.findall('>([^<>]*)</a>',url)

非贪婪匹配 只是影响结束位置,不影响开始位置。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-7-2 23:40:31 | 显示全部楼层
import re
url ='<2><3><4><5><6><7><8>'
res1 = re.findall('<(.*?)>',url)
for each in res1:
    print (each)
res2 = re.findall('<(.*)>',url)
for each in res2
    print (each)
结果:res1 2345679
         res2 2><3><4><5><6><7><8
显然,非贪婪指的是遇到末尾的匹配,就停止,然后在进行一次匹配,
贪婪指的是遇到最后一个末尾的匹配,尽可能的匹配更长的字符串
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-7-3 00:08:49 | 显示全部楼层


贪婪不贪婪的不懂 不过如果
url改一下就看出效果了:
  1. >>> url = '<span>"|</span><a target="_blank" >帮助</a><span>"|</span><a target="_blank" >帮助</a><span>"|</span><a target="_blank" >帮助</a>'
  2. >>> res = re.findall('>(.*?)</a>',url)
  3. >>> res
  4. ['"|</span><a target="_blank" >\xe5\xb8\xae\xe5\x8a\xa9', '"|</span><a target="_blank" >\xe5\xb8\xae\xe5\x8a\xa9', '"|</span><a target="_blank" >\xe5\xb8\xae\xe5\x8a\xa9']
  5. >>> res = re.findall('>(.*)</a>',url)
  6. >>> res
  7. ['"|</span><a target="_blank" >\xe5\xb8\xae\xe5\x8a\xa9</a><span>"|</span><a target="_blank" >\xe5\xb8\xae\xe5\x8a\xa9</a><span>"|</span><a target="_blank" >\xe5\xb8\xae\xe5\x8a\xa9']
复制代码


有点乱 .*匹配最长的为一条了 .*?匹配到了所有最短的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-7-5 09:35:10 | 显示全部楼层
你想要匹配的是什么呢?最近也在学正则
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-7-6 12:37:30 | 显示全部楼层
你如果只想匹配<a>标签中的内容,就把<a>标签写上啊,这样就不会匹配到其他内容了。
>>> import re
>>> url = '<span>"|</span><a target="_blank" >帮助</a>'
>>> re.findall('<a .*>(.*?)</a>', url)
['帮助']
>>>
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-12-22 06:00

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表