免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2943 | 回复: 1
打印 上一主题 下一主题

【求助】python多行匹配的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-10-02 10:43 |只看该作者 |倒序浏览
  1. typedef union {
  2. ...
  3. } AA;

  4. typedef union {
  5. ...
  6. } BB;

  7. typedef union {
  8. ...
  9. } CC;
复制代码
我想中上面的的文本中提取出 union CC的定义。

我试了下以下正则式:
  1. re.compile(r'typedef union \{(.*?)\} CC', re.S|re.M)
复制代码
得到的结果是:
  1. >>> pat.search(msg).groups()[0]                              
  2. ' \n...\n} AA;\n\ntypedef union { \n...\n} BB;\n\ntypedef union { \n...\n'
复制代码
好像没有去处掉组选( .* )的贪婪。

请各位大大帮忙,谢谢。

论坛徽章:
0
2 [报告]
发表于 2011-10-03 11:00 |只看该作者
本帖最后由 xxm789520 于 2011-10-03 11:08 编辑

我有一个笨办法,就是先匹配所有的函数,放入数组,再查找匹配CC的函数
使用^和$限定行首和行尾会更加有效
  1. import re

  2. s='''
  3. typedef union {
  4. ...
  5. } AA;

  6. typedef union {
  7. ...
  8. } BB;

  9. typedef union {
  10. ...
  11. } CC;
  12. '''
  13. c=re.compile('(^typedef union {$.*?^} \w+;$)', re.S|re.M)
  14. g=c.findall(s)


  15. for gg in g:
  16.     if re.search('CC;$',gg):
  17.         print gg
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP