Mam plik XML, w którym kod poniżej się powtarzakilkaset razy. Muszę usunąć wszystkie przypadki, w których Block Name = "ZG123CZ123". Zamiast usuwania początku w wierszu, w którym spełniony jest warunek nazwy aplikacji, należy rozpocząć od <device>
i kończ na </device>
do całkowitego usunięcia, gdy spełniony jest warunek aplikacji. Jak dokładnie miałbym to robić przy użyciu zamienników RegEx Notepad ++?
<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>
Odpowiedzi:
1 dla odpowiedzi № 1Użyj tego:
(?s)<Device(?:(?!</Device).)*<Block[^>]+Name="ZG123CZ123".*?</Device>
Wyjaśnienie:
(?s)
to modyfikator jednowierszowy, który sprawia, że.
zawierać znaki nowej linii.<Device
szuka początkuDevice
element.(?:(?!</Device).)*
jest zasadniczo.*
, ale za każdym razem, gdy próbujemy dopasować postać, upewniamy się, że nie pasujemy do końca znakuDevice
element (</Device
) przy użyciu negatywnego spojrzenia w przyszłość. Zauważ, że nie możesz po prostu uczynić tego leniwym dopasowaniem, ponieważ trwałoby to do momentu znalezienia<Block Name="ZG123CZ123">
(to kolejny kawałek).<Block[^>]+Name="ZG123CZ123"
będzie szukał początkuBlock
element, po którym następuje non>
znak (i), po których następujeName
atrybut równyZG123CZ123
..*?
jest leniwym zapałem do zjedzenia resztyDevice
element.</Device>
dotarliśmy do końca!