我有一个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>
答案 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
我们已经到了最后!