just_itt Geschrieben 13. Juni 2002 Geschrieben 13. Juni 2002 Hi, ich hätte ein paar fragen zu dem Codefragment. Das ganze ist in Perl geschrieben und da ich leider kein Perl kann kenn ich mcih net ganz so aus. open macht nach meinem Verständnis eine Datei auf, deren Pfad als Variable $mbox übergeben wird. Und ich vermute, das MBOX als "interner Name" verwendet wird. Stimmt das so? Mir ist nur nicht klar was while (<MBOX>) bewirkt. Ich kenne zwar while, aber was macht <MBOX> ? Beim rest denk ich das er die DAtei nach From durchsucht, und jedes mal wen er eins findet wieder in ne neue Datei schreibt, wobei darauf geachtet wird das keine Datei doppelt geschrieben wird. mit Close macht er das zeugs dann wieder zu. Wenn ich das script laufen lasse, bekomme ich eine fehler beim letzten Close(Cyrus .... Er sagt mir das es 0. nicht schließen konnte. Aber nach meinem Verständnis sollte es doch gar kein 0. geben. :confused: Wäre spitze wenn mir jemand helfen könnte!! Danke Just_itt -------------------------------------- Code -------------------------------------- use strict; use Getopt::Long; my $mbox = ""; my $path = ""; my $countstart = 0; my $i = 0; GetOptions('mbox=s' => \$mbox, 'path=s' => \$path, 'countstart=i' => \$countstart, 'usage' => sub {usage}); $i = $countstart; open(MBOX, $mbox) || die "can't open $mbox \n"; unless ($path eq "") { chdir($path) || die "bla" ; } while (<MBOX>) { chomp; if (/^From /) { print Variable $i unless ($i == $countstart) {close(CYRUS) || die "can't close $i. \n";} $i++; while (-e "$i.") {$i++;} open(CYRUS, ">$i.") || die "can't open $i. \n"; } print CYRUS $_ . "\x0D\x0A"; } close(MBOX) || die "can't open $mbox \n"; close(CYRUS) || die "can't close $i. \n"; exit(0);
dr.disk Geschrieben 13. Juni 2002 Geschrieben 13. Juni 2002 Punkt 1: <MBOX> der Befehl <MBOX> liest eine Zeile aus der Datei und gibt wahr zurück solange er was lesen konnte. Die gelesene Zeile steht in der Variablen $_. while (<MBOX>) liest also zeilenweise eine Datei ein. Punkt 2: auf die Schnelle betrachtet ist die Kombination der beiden close(CYRUS) schuld. Kommentiere mal beide aus und setze close(CYRUS) direkt unter die Zeile print CYRUS $_ . "\x0D\x0A"; , also noch vor }.
networkd Geschrieben 19. Juni 2002 Geschrieben 19. Juni 2002 Hallo, er gibt dir AFAIS eine Fehlermeldung beim ersten close(CYRUS), weil CYRUS garnicht geöffnet ist. Tipps: starte Perl mit dem Switch -w (oder #!/bin/perl -w in der erste Zeile)verwende use diagnostics Gruß
Empfohlene Beiträge
Erstelle ein Benutzerkonto oder melde Dich an, um zu kommentieren
Du musst ein Benutzerkonto haben, um einen Kommentar verfassen zu können
Benutzerkonto erstellen
Neues Benutzerkonto für unsere Community erstellen. Es ist einfach!
Neues Benutzerkonto erstellenAnmelden
Du hast bereits ein Benutzerkonto? Melde Dich hier an.
Jetzt anmelden