#! /usr/bin/perl -w # Auch strict verwenden use strict; my $Kursname = "server12.KursServer"; my $KursErg = "Ergebnis.Log"; my $Logpath = "data/home/user1/Perl"; my $Log = "$Kursname.2009-08-21.log"; my $Variable = "HTTP ERROR"; # Das ist kein korrektes open: #open ($Logpath, ""); #print "Error message: text/Log\n"; # korrekt: open(my $logfh, '<',"$Logpath/$Log") or die "ERROR open("$Logpath/$Log") ($!)\n"; # my vergessen! my @ErrorList = (); # nicht korrekt, # es existieren die Variablen nicht! #foreach $Line (Logpath) # korrekt: #foreach my $Line (<$logfh>) # hier wird aber die gesamte Datei auf einmal eingelesen, # was gerade bei Logfiles zu einem extremen Speicherverbrauch führt # besser: while(my $Line=<$logfh>) { # falsch das ist eine Zuweisung und kein Vergleich #if ($Line = ($Variable)) # korrkt: #if($Line eq $Variable) # das prüft aber, # ob die gesamte Zeile wie der String in "$Variable" aussieht # was du vermutlich willst, # ist zu wissen ob der String in "$Variable" in "$Line" enthalten ist # besser: if(index($Line,$Variable)>-1) { # Was willst du hier bitte ausgeben "$" ist keine Variable #print "- ".$."
"; # und es exstiert auch kein "$KursErg" das ein anonymes Array ist # und "$1" ist leer, da du keinen regulären Ausdruck verwendet hast. #push(@$KursErg, $1); # ich vermute du willst das hier machen: print "$Line
\n"; push(@ErrorList,$Line); } } close $logfh; # das kann man so machen #open (OUT,">KursErg"); # besser: open(my $outfh, '>', "$KursErg") or die "ERROR open($KursErg) ($!)\n"; # das ist so nicht korrekt #print OUT @$KursErg; # richtig: print $outfh join('',@ErrorList); # alternativ: # ("foreach" ist gleichbedeutend mit "for", perl erkennt was gemeint ist) # for my $line (@ErrorList) # { # print $outfh $line; # } close $outfh;