Mal ein kleines unvollständiges Beispiel. Zuerst alle "Blöcke" in ein Hash/Dictionary lesen und in einem Array ablegen. Dann das Array abklappern und die Elemente (aus den Hashes) raussuchen auf die das Filterkriterium zutrifft. Gibt natürlich viele andere Möglichkeiten.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
#!/usr/bin/perl
use strict;
use warnings;
use Data::Dumper;
my @entries;
my @filtered;
my $event = {};
while (<>) {
chomp;
unless ($_) {
push @entries, $event if keys %$event;
$event = {};
next;
}
if (/^(\w+):\s?(.+)$/) {
$event->{$1} = $2;
} else {
$event->{msg_text} .= $_."\n";
}
}
@filtered = grep { $_->{Severity} =~ /Error/ } @entries;
die Dumper \@filtered;
Aufruf via:
$ perl skript.pl logfile.txt
\n\n
<!--EDIT|Ronnie|1144876210-->