找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 16250|回复: 4

[问题求助] [已解决]Python正则表达式match不能正确匹配,求指导

[复制链接]
发表于 2016-5-14 23:46:12 | 显示全部楼层 |阅读模式
本帖最后由 回家路上 于 2016-5-17 23:03 编辑

  1. reg = re.compile(r"^[^()]+$|(?<=\()[^)]+")
  2. print(reg.findall("没有括号匹配全部内容"))
  3. print(reg.findall("aaaaaaa(有括号匹配括号里内容)"))

  4. print(reg.match("没有括号匹配全部内容"))
  5. print(reg.match("aaaaaaa(有括号匹配括号里内容)"))
复制代码
Python语言:同一个编译的reg,上面的findall可以匹配到,下面的match匹配不到
求前辈们指导怎么回事?
发表于 2016-5-15 03:41:42 | 显示全部楼层
finall会试图找出所有能匹配的内容。

match 默认头开 查找,如果不匹配,应该是不回头了的。
http://www.cnblogs.com/huxi/archive/2010/07/04/1771073.html

评分

参与人数 1技术 +1 收起 理由
回家路上 + 1 乐于助人

查看全部评分

 楼主| 发表于 2016-5-15 13:49:09 | 显示全部楼层
确实,re.match是从字符串开头进行匹配

  1. reg = re.compile(r"^[^()]+$|(?<=\()[^)]+")
复制代码
改为
reg = re.compile(r"^[^()]+$|.*(?<=\()([^)]+)")

多谢了哈。
发表于 2016-5-15 14:33:51 | 显示全部楼层
我的理解的是match更适合用来匹配一个字符是不是手机号或者邮箱的场合。
如果用来提取一大篇内容里所有的手机号,我更喜欢用findall
  1. >>> m=re.match(r".*[\(\[](.+)[\)\]]","sfsf(有括号匹配括号里内容)")
  2. >>> m.group(1)
  3. '有括号匹配括号里内容'
复制代码
一定要用match的话,也可以子组来匹配出括号中的内容。
发表于 2016-5-15 14:37:18 | 显示全部楼层
^[^()]+$ 这条正则串不匹配的原因是整条字符串中有括号了。

(?<=\()[^)]+ 这条不匹配的原因是a不是(,所以匹配就失败了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-17 06:24 , Processed in 0.023508 second(s), 12 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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