V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
PopRain
V2EX  ›  问与答

求教,如何在用正则表达式匹配特定标签中特定内容

  •  
  •   PopRain · 2020-04-12 13:10:35 +08:00 · 1149 次点击
    这是一个创建于 1687 天前的主题,其中的信息可能已经有所发展或是发生改变。

    需要匹配的文本内容:

    <Reference Include="DevExpress.Pdf.v17.2.Core, Version=17.2.11.0, Culture=neutral, PublicKeyToken=b88d1754d700e49a"> <Private>False</Private> </Reference> <Reference Include="DevExpress.Office.v17.2.Core, Version=17.2.11.0, Culture=neutral, PublicKeyToken=b88d1754d700e49a"> <Private>True</Private> </Reference>

    希望能匹配出第 2 条,条件是:标签 <Reference> </<Reference> 包括 DevExpress 和 <Private>True</Private>

    谢谢!

    4 条回复    2020-04-12 16:47:27 +08:00
    Geekgogo
        1
    Geekgogo  
       2020-04-12 13:53:35 +08:00
    import re
    str = '内容'
    pattern = r'\<Reference (.*?)\<\/Reference\>'
    re.findall(patter, str)
    PopRain
        2
    PopRain  
    OP
       2020-04-12 14:16:20 +08:00
    @Geekgogo 全文很多记录,其中有两条记录记录包括 DevExpress,在这两条记录里面,希望能匹配到第二条记录(包括<Private>True</Private>)。

    我是想选出包括 DevExpress 引用,属性 Private 为 True 的记录。

    谢谢!
    imn1
        3
    imn1  
       2020-04-12 15:51:28 +08:00
    #2
    你按数组下标找就是了,findall 输出是数组

    想直接匹配,就
    r'(<Reference[\s\S]+?(?=.+?Private>True</Private>\s*?)</Reference>)'
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2892 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 00:07 · PVG 08:07 · LAX 16:07 · JFK 19:07
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.