Учитывая большой входной файл, который выглядит следующим образом:
02/26/2012 08:54:38 Error:java.sql.Exception
02/26/2012 08:54:48 Error:java.sql.Exception
02/26/2012 08:56:05 Error:java.sql.Exception
02/26/2012 08:57:21 Error:java.sql.Exception
02/26/2012 08:59:29 Error:java.sql.Exception
02/26/2012 09:01:14 Error:java.sql.Exception
02/26/2012 09:08:48 Error:java.sql.Exception
02/26/2012 09:10:41 Error:java.sql.Exception
Я пытаюсь выяснить количество ошибок в час;то есть я ищу выходной файл, который выглядит следующим образом:
02/26/2012 08 -> 5
02/26/2012 09 -> 3
Вот скрипт, который работает для меня:
#!/bin/perl
open(MYFILE, 'tata2');
my %table;
while (<MYFILE>) {
chomp;
$dtkey = substr $_, 0, 13;
$table{$dtkey}++;
}
close(MYFILE);
for my $key (keys %table) {
print "$key -> $table{$key}\n";
}
Но, учитывая возможности Perl, яЯ уверен, что это можно сделать в несколько строк.Я был бы очень признателен, если бы вы могли привести несколько примеров.Я надеюсь, что это будет полезно для тех, кто хочет сократить количество строк кода, написанного для достижения чего-либо.