|
Allgemeines zu vordefinierten Variablen
Vordefinierte Skalare
Vordefinierte Listen und Hashs
Perl-eigene Umgebungsvariablen
Skalar | Erläuterung | Beispiel |
---|---|---|
$_ | Die bekannteste vordefinierte Variable in Perl. Sie enthält in Suchläufen (z.B. bei der Suche in einer Liste) den jeweils aktuellen Wert. Sie kann direkt in die Suche integriert werden, ohne daß eine selbst definierte Variable erforderlich ist. Das nebenstehende Beispiel gibt einfach der Reihe nach alle Zahlen aus, die in der Liste @Zahlen definiert wurden. |
@Zahlen = (1..10); for(@Zahlen) { print $_, "\n"; } |
$. | Enthält die aktuelle Zeilennummer der zuletzt eingelesenen Datei. Im nebenstehenden Beispiel werden alle Zeilen einer Textdatei eingelesen und ausgegeben. Am Ende kann $. darüber Auskunft geben, wie viele Zeilen eingelesen wurden. |
open(DATEI, "<readme.txt"); while(<DATEI>) { print $_; } print $., " Zeilen gelesen"; close(DATEI); |
$/ | Enthält den eingestellten Eingabeseparator. Kann geändert werden - auch mehrere Zeichen sind erlaubt. Das nebenstehende Beispiel bewirkt, daß eine Eingabe von der Standardeingabe erst dann abgeschlossen ist, wenn der Anwender die Zeichenfolge ENDE eingibt und <Return> drückt. |
$/ = "ENDE"; $DeinName = <STDIN>; print $DeinName; |
$] | Enthält die Versionsnummer des verwendeten Perl-Interpreters. Gut geeignet, um bei Scripts die Ausführung des restlichen Programmcodes davon abhängig zu machen, daß der Perl-Interpreter mindestens eine bestimmte Versionsnummer hat. |
if($] < 5) { die "Perl-Interpreter zu alt"; } else { print $]; } |
$! | Enthält eine im aktuellen Programm-Kontext aktuelle Fehlermeldung oder Fehlernummer, sofern ein Fehler aufgetreten ist. Die nebenstehende Anweisung versucht eine Datei zu öffnen und gibt im Fehlerfall die vordefinierte Perl-Fehlermeldung aus, wenn die Datei nicht geöffnet werden kann. | open(DATEI, "<nixda.txt") || print $!; |
$0 | Enthält den Dateinamen des Perl-Scripts, das gerade ausgeführt wird. Wert kann geändert werden. | print $0, " wird ausgefuehrt!"; |
$$ | Enthält die Prozeß-ID des Perl-Scripts, das gerade ausgeführt wird. Vor allem unter Unix von Interesse. | "Prozess ", $$, " wird ausgefuehrt!"; |
$^T | Enthält den genauen Zeitpunkt (Millisekunden), zu dem das Script gestartet wurde. Das nebenstehende Beispiel stellt einen kleinen Benchmark-Test dar. Es führt eine lange Schleife von Berechnungen durch und ermittelt, wie lange das Perl-Script dazu braucht. |
@Zahlen = (1..50000); for(@Zahlen) { $x = sqrt($_); } $Start = $^T; $Jetzt = time; print "Laufzeit: ", $Jetzt - $Start, " ms\n"; |
$& | Enthält nach Anwenden eines regulären Ausdrucks den Wert, auf den das Suchmuster paßte. |
$Satz = "Mann und Frau"; $Satz =~ /\bund\b.*/; print $&; |
$& | Enthält nach Anwenden eines regulären Ausdrucks mit Klammern den Inhalt der Klammer, die mit dem letzten Suchmuster übereinstimmte. |
$Satz = "Mann und Frau"; $Satz =~ /(\bund\b).*/; print $+; |
$1, $2, usw. | Enthält nach Anwenden eines regulären Ausdrucks mit Klammern die Werte der Klammern 1, 2 usw., auf die das in der jeweiligen Klammer definierte Suchmuster paßte. |
$Satz = "Mann und Frau und Kind"; $Satz =~ /(\bund\b).*\1/; print $1; |
Liste/Hash | Erläuterung | Beispiel |
---|---|---|
@_ | Enthält die Parameter, die beim Aufruf eines Unterprogramms übergeben wurden. Innerhalb des Unterprogramms sind die üpbergebenen Parameter mit $_[0] (= erster Parameter), $_[1] (= zweiter Parameter) usw. ansprechbar. |
&Sprich("Hallo Welt"); sub Sprich { print $_[0]; } |
@ARGV | Enthält die Parameter, die beim Aufruf des Perl-Scripts mit übergeben wurden. Wenn z.B. perl test.pl meintext.txt eingegeben wurde, ist meintext.txt der erste Parameter aus Sicht des Perl-Scripts. Das Script kann Parameter als Input für den Programmablauf auswerten. Im nebenstehenden Beispiel wird der erste übergebene Parameter $ARGV[0] als Dateiname interpretiert. Das Script versucht, diese Datei zu öffnen. |
open(DATEI, "<$ARGV[0]") || die "Fehler!"; print $ARGV[0], " geoeffnet!"; close(DATEI); |
%ENV | Enthält die komplette Rechnerumgebung, wie Sie dem Perl-Interpreter bekannt ist (geladene Treiber, Systemprogramme usw.). Das nebenstehende Beispiel gibt die Elemente der in diesem Hash gespeicherten Daten aus. |
for(%ENV) { print $_, "\n"; } |
Variable | Erläuterung |
---|---|
HOME | Enthält das Verzeichnis, zu dem gesprungen werden soll, wenn eine chdir-Anweisung keine Parameter enthält (Unix-typisch) |
PATH | Enthält den kompletten Pfad, d.h. alle Verzeichnisse, in denen nach ausführbaren Programmen gesucht werden soll. Wird von Perl benutzt, wenn aus einem Perl-Script andere Perl-Scripts aufgerufen werden, deren Lage nicht näher angegeben ist. |
Blättern: | |||
Variablen und Datentypen | Bedingte Anweisungen |
HTML-Dateien selbst erstellen | |||
Dokumentation: CGI/Perl | |||
CGI und Perl: Perl Sprachelemente |
© 1997 Stefan Münz, s.muenz@euromail.com