使用RegEx和Notepad ++进行批量替换

时间:2014-09-24 20:13:52

标签: regex notepad++

我有一个xml文件,下面的代码重复了几百次。我需要删除Block Name =“ZG123CZ123”的所有实例。它不是在满足应用名称条件的行上开始删除,而是需要从<device>开始并在</device>结束,以完全删除满足应用程序条件的位置。我将如何使用Notepad ++ RegEx替换来完成此操作?

<Device DevID="14212111" Model="" GroupID="">
  <Block Name="DG" LastFileDld="" LastFullDld="">
    <Group ZD="3">
      <DSize ParamName="*UNZIP" Value="DG.ZIP"/>
      <DSize ParamName="*GO" Value="F:DG.OUT"/>
    </Group>
    <Group ZD="15">
      <DSize ParamName="#LOGPORT" Value="NONE"/>
      <DSize ParamName="CDH6" Value=""/>
    </Group>
  </Block>
  <DevFiles />
</Device>
<Device DevID="14212111" Model="" GroupID="">
  <Block Name="ZG123CZ123" LastFileDld="" LastFullDld="">
    <Group ZD="1">
      <DSize ParamName="KEY" Value="RAM"/>
      <DSize ParamName="REM" Value="***"/>
      <DSize ParamName="*UNZIP" Value="I:ZG123CZ123.ZIP"/>
    </Group>
    <Group ZD="15">
      <DSize ParamName="REM" Value="="***""/>
      <DSize ParamName="#DEBUGPORT" Value=""/>
    </Group>
  </Block>
  <DevFiles />
</Device>

1 个答案:

答案 0 :(得分:1)

使用此功能:

(?s)<Device(?:(?!<\/Device).)*<Block[^>]+Name="ZG123CZ123".*?<\/Device>

<子> Demo


<强>解释

  • (?s)是单行修饰符,可使.包含换行符。
  • <Device查找Device元素的开头。
  • (?:(?!<\/Device).)*基本上是.*,但每次我们尝试匹配某个字符时,请确保我们不匹配Device元素的结尾({{1}通过使用负向前瞻。请注意,您不能将其设为惰性匹配,因为它会一直持续到找到<\/Device(即下一个块)。
  • <Block Name="ZG123CZ123">将查找<Block[^>]+Name="ZG123CZ123"元素的开头,后跟非Block个字符,然后>属性等于Name
  • ZG123CZ123是一个懒惰的匹配,可以吃掉.*?元素的剩余部分。
  • Device我们已经到了最后!