Saya mencoba menggunakan Notepad ++ dan ekspresi reguler untuk menghapus semua XML dari acara Windows.
Ekspresi reguler saya adalah sebagai berikut:
Event Xml:(.|\n)+?Event>\n
Contoh acara Windows adalah sebagai berikut:
Log Name: System
Source: Service Control Manager
Date: 2016/04/29 11:54:00
Event ID: 7036
Task Category: None
Level: Information
Keywords: Classic
User: N/A
Computer: hostname.domainname
Description:
The Adobe Flash Player Update Service service entered the stopped state.
Event Xml:
<Event xmlns="http://schemas.microsoft.com/win/2004/08/events/event">
<System>
<Provider Name="Service Control Manager" Guid="{555908d1-a6d7-4695-8e1e-26931d2012f4}" EventSourceName="Service Control Manager" />
<EventID Qualifiers="16384">7036</EventID>
<Version>0</Version>
<Level>4</Level>
<Task>0</Task>
<Opcode>0</Opcode>
<Keywords>0x8080000000000000</Keywords>
<TimeCreated SystemTime="2016-04-29T10:54:00.113587400Z" />
<EventRecordID>299771</EventRecordID>
<Correlation />
<Execution ProcessID="696" ThreadID="3904" />
<Channel>System</Channel>
<Computer>hostname.domainname</Computer>
<Security />
</System>
<EventData>
<Data Name="param1">Adobe Flash Player Update Service</Data>
<Data Name="param2">stopped</Data>
<Binary>410064006F006200650046006C0061007300680050006C0061007900650072005500700064006100740065005300760063002F0031000000</Binary>
</EventData>
</Event>
Log Name: System
Source: Service Control Manager
Date: 2016/04/29 11:54:00
Event ID: 7036
Task Category: None
Level: Information
Keywords: Classic
User: N/A
Computer: hostname.domainname
Description:
The Adobe Flash Player Update Service service entered the running state.
Event Xml:
<Event xmlns="http://schemas.microsoft.com/win/2004/08/events/event">
<System>
<Provider Name="Service Control Manager" Guid="{555908d1-a6d7-4695-8e1e-26931d2012f4}" EventSourceName="Service Control Manager" />
<EventID Qualifiers="16384">7036</EventID>
<Version>0</Version>
<Level>4</Level>
<Task>0</Task>
<Opcode>0</Opcode>
<Keywords>0x8080000000000000</Keywords>
<TimeCreated SystemTime="2016-04-29T10:54:00.113587400Z" />
<EventRecordID>299770</EventRecordID>
<Correlation />
<Execution ProcessID="696" ThreadID="3904" />
<Channel>System</Channel>
<Computer>hostname.domainname</Computer>
<Security />
</System>
<EventData>
<Data Name="param1">Adobe Flash Player Update Service</Data>
<Data Name="param2">running</Data>
<Binary>410064006F006200650046006C0061007300680050006C0061007900650072005500700064006100740065005300760063002F0034000000</Binary>
</EventData>
</Event>
Ekspresi reguler yang disebutkan di atas berfungsi di http://www.regexpal.com/ :
Ekspresi reguler yang disebutkan di atas tidak berfungsi di Notepad ++:
notepad++
regex
find-and-replace
event-viewer
mitos mesin
sumber
sumber
\r\n
, Unix\n
, Mac lama\r
. Ini bisa jadi menyebalkan.Event Xml:(.|\r\n)+?Event>
melakukan hal yang sama dengan regexEvent Xml:(.*?)Event>
dan regexEvent Xml:(.|\r\n)+?Event>\r\n
hanya mengganti instance pertama karena kurangnya akhir baris file yang sudah ada sebelumnya. Adakah ide bagaimana juga menghapus baris baru?Event Xml:(.*?)Event>[\r\n]+
atau gunakanEvent Xml:(.*?)Event>
lalu ganti[\r\n]+
dengan\r\n
.Ekspresi reguler
\r\nEvent Xml:(.|\r\n)+?Event>
berfungsi persis seperti yang diinginkan dalam menghapus semua instance tanpa menghiraukan baris akhir file dan tanpa mengaktifkan opsi ". Cocok dengan baris baru".Sebelum:
Setelah:
Terima kasih kepada @DavidPostill dan @Sylordis dalam membantu saya mengetahui hal ini!
sumber
Anda harus mencentang opsi ". Cocok dengan baris baru" di notepad ++, jika tidak, ekspresi reguler hanya dianggap sebagai baris per baris.
sumber