免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2799 | 回复: 1

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

论坛徽章:
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
发表于 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
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

DTCC2020中国数据库技术大会

【架构革新 高效可控】2020年12月21日-23日第十一届中国数据库技术大会将在北京隆重召开。

大会设置2大主会场,20+技术专场,将邀请超百位行业专家,重点围绕数据架构、AI与大数据、传统企业数据库实践和国产开源数据库等内容展开分享和探讨,为广大数据领域从业人士提供一场年度盛会和交流平台。

http://dtcc.it168.com


大会官网>>
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP