douqie3391 2014-07-28 12:40
浏览 19
已采纳

PHP preg匹配错误捕获

I want to capture <div class='troll'><goodTag/>trololoQWE</div> (1)

and <div class='troll'>trololo123</div> (2)

and <div class='troll'>besttrololo123</div> (3)

but ignore <div class='troll'><badTag/>trololoASD</div> (4)

I tried this regexp: /<div class='troll'>([^(<badTag\/>)].*?)<\/div>/

but then I can capture only (2) :(

How to correctly ignore long text from first position of capture group ??

Edit: I want catch all content of this div, but ignore if first item is <badTag>

  • 写回答

2条回答 默认 最新

  • douqin231881 2014-07-28 12:53
    关注

    You should use the following regex:

    /(<div class='troll'>(?!<badTag\/>).*<\/div>)/
    

    Demo

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 ADS生成的微带线为什么是蓝色空心的
  • ¥15 求一下解题思路,完全不懂
  • ¥15 tensorflow
  • ¥15 densenet网络结构中,特征以cat方式复用后是怎么进行误差回传的
  • ¥15 STM32G471芯片spi设置了8位,总是发送16位
  • ¥15 R语言并行计算beta-NTI中tree文件的类型
  • ¥15 如何解读marsbar导出的ROI数据?
  • ¥20 求友友协助弄一下基于STC89C52单片机的声光控制灯原理图
  • ¥15 arduino双向交通灯设计
  • ¥15 有没有会粒子群算法的大能(○゜ε^○)求带不会出收敛图😭