NAME
Quiq::FileHandle - Datei-Handle
BASE CLASS
SYNOPSIS
Datei schreiben:
my $fh = Quiq::FileHandle->new('>',$path);
$fh->print("Test\n");
$fh->close;
Datei lesen:
my $fh = Quiq::FileHandle->new('<',$path);
while (<$fh>) {
print;
}
$fh->close;
Programm darf nur einmal laufen:
my $fh = eval{Quiq::FileHandle->new('<',$file,-lock=>'EXNB')};
if ($@) {
exit 5;
}
Zähler-Datei mit Locking:
my $fh = Quiq::FileHandle->new('+>>',$file,-lock=>'EX');
$fh->seek(0);
my $count = <$fh> || "0\n";
chomp $count;
$fh->truncate;
$fh->print(++$count,"\n");
# Der Lock bleibt so lange bestehen bis $fh aus dem Scope geht
Siehe auch Quiq::LockedCounter.
DESCRIPTION
Ein Objekt der Klasse repräsentiert eine Dateihandle, über die Daten gelesen oder geschrieben werden können.
METHODS
Konstruktor
new() - Öffne Dateihandle
Synopsis
$fh = $class->new($mode,$path,@opt);
$fh = $class->new($globRef,@opt);
$fh = $class->new('<'); # Lesen von STDIN
$fh = $class->new('>'); # Schreiben nach STDOUT
Alias
open()
Options
- -createDir => $bool (Default: 0)
-
Erzeuge den Verzeichnispfad einer Datei, die geschrieben wird, falls er nicht existiert.
- -lock => 'EX'|'SH'|'EXNB'|'SHNB' (Default: kein Lock)
-
Locke die Dateihandle nach dem Öffnen im angegebenen Lock-Modus. Folgende Lockmodes werden unterschieden: 'SH' (shared lock), 'EX' (exclusive lock). Durch den Zusatz 'NB' (also Lockmode 'SHNB' der 'EXNB') wird die Operation "non blocking" ausgeführt, d.h. wenn der Lock nicht sofort erworben werden kann, wird eine Exception ausgelöst.
Wurde die Datei vom Konstruktor geöffnet, schließt er sie, wenn der Lock nicht erworben werden kann. Andernfalls bleibt die Dateihandle geöffnet.
Description
Instantiiere Dateihandle-Objekt und liefere eine Referenz auf dieses Objekt zurück.
Examples
Filehandle-Objekt für STDOUT:
$fh = Quiq::FileHandle->new(\*STDOUT);
Lesen von STDIN:
$fh = $class->new('<');
$fh = $class->new('<','');
$fh = $class->new('<','-');
Schreiben nach STDOUT:
$fh = $class->new('>');
$fh = $class->new('>','');
$fh = $class->new('>','-');
close() - Schließe Dateihandle
Synopsis
$fh->close;
Alias
destroy()
Description
Schließe Dateihandle. Die Methode liefert keinen Wert zurück. Nach Aufruf der Methode ist die Objektreferenz ungültig.
DESTROY() - Schließe Dateihandle
Synopsis
$fh->DESTROY;
Description
Schließe Dateihandle. Die Methode liefert keinen Wert zurück.
Lesen
read() - Lies Daten von Dateihandle
Synopsis
$data = $fh->read($n);
Description
Lies die nächste die nächsten $n Zeichen von Dateihandle $fh und liefere diese zurück. Ist das Dateiende erreicht, liefere undef.
readData() - Lies Daten mit Längenangabe
Synopsis
$data = $fh->readData;
Description
Lies Daten in der Repräsentation
<LENGTH><DATA>
und liefere <DATA> zurück. <LENGTH> ist ein 32 Bit Integer und <DATA> sind beliebige Daten mit <LENGTH> Bytes Länge.
Wurden die Daten in einem Encoding wie UTF-8 geschrieben, müssen diese nach dem Einlesen anscheinend nicht dekodiert werden. Warum?
Wurden die Daten $data in einem Encoding wie UTF-8 geschrieben, müssen diese anschließend decodiert werden mit
Encode::decode('utf-8',$data);
Auf der FileHandle $fh das Encoding zu definieren, ist nicht richtig, da die Längenangabe diesem Encoding nicht unterliegt!
See Also
writeData()
readLine() - Lies Zeile von Dateihandle
Synopsis
$line = $fh->readLine;
Description
Lies die nächste Zeile von Dateihandle $fh und liefere diese zurück. Schlägt dies fehl, wirf eine Exception.
readLines() - Lies mehrere Zeilen von Dateihandle
Synopsis
@lines|$lineA = $fh->readLines($n);
Description
Lies die nächsten $n Zeilen von Dateihandle $fh und liefere diese als Liste zurück. Der Zeilentrenner am Ende jeder Zeile wird entfernt. Im Skalarkontext liefere eine Referenz auf die Liste, wenn Zeilen gelesen wurden, sonst undef
.
Example
Liefere Chunks von 1000 Pfaden:
my $fh = Quiq::FileHandle->new('-|',"find @$dirA -name '*.xml.gz'");
while (my $fileA = $fh->readLines(1000)) {
...
}
$fh->close;
readLineChomp() - Lies Zeile ohne Zeilentrenner von Dateihandle
Synopsis
$line = $fh->readLineChomp;
Description
Lies die nächste Zeile von Dateihandle $fh, entferne den Zeilentrenner mit chomp() und liefere das Resultat zurück.
readLineNoWhiteSpace() - Lies Zeile und entferne Whitespace am Ende
Synopsis
$line = $fh->readLineNoWhiteSpace;
Description
Lies die nächste Zeile von Dateihandle $fh, entferne jeglichen Whitespace am Zeilenende (mit s/\s+$//) und liefere das Resultat zurück.
Diese Funktion ist nützlich, wenn verschiedene Zeilentrenner CRLF oder LF vorkommen können und Zeilen nur mit Whitespace zu Leerzeilen reduziert werden sollen.
getc() - Lies nächstes Zeichen
Synopsis
$c = $fh->getc;
slurp() - Lies Rest der Datei
Synopsis
$data = $fh->slurp;
Returns
String
Description
Lies den Rest von Dateihandle $fh liefere diesen zurück.
Die Methode ist nützlich, wenn der gesamte Inhalt einer Datei ab einer bestimmten Position gelesen werden soll.
Example
Lies gesamten Inhalt einer Datei ab Position $pos:
my $fh = Quiq::FileHandle->open('<',$logFile);
$fh->seek($pos);
my $data = $fh->slurp;
Schreiben
print() - Schreibe Daten auf Dateihandle
Synopsis
$fh->print(@data);
Alias
write()
Description
Schreibe Daten @data auf Dateihandle $fh. Die Methode liefert keinen Wert zurück.
writeData() - Schreibe Daten mit Längenangabe
Synopsis
$fh->writeData($data);
Description
Schreibe die Daten $data in der Repräsentation
<LENGTH><DATA>
Hierbei ist <LENGTH> ein 32 Bit Integer, der die Länge der darauffolgenden Daten <DATA> in Bytes angibt.
Liegen die Daten $data in einem Encoding wie UTF-8 vor, müssen diese zuvor encodiert werden mit
Encode::encode('utf-8',$data);
Auf der FileHandle $fh das Encoding zu definieren, ist nicht richtig, da die Längenangabe diesem Encoding nicht unterliegt!
See Also
readData()
truncate() - Kürze Datei
Synopsis
$fh->truncate;
$fh->truncate($length);
Description
Kürze Datei auf Länge $length. Ist $length nicht angegeben, kürze Datei auf Länge 0.
Positionieren
seek() - Setze Position in Datei
Synopsis
$fh->seek($pos);
$fh->seek($pos,$whence);
Description
Setze die Position der Filehandle in der Datei. Die Methode liefert keinen Wert zurück. Genaue Funktionsbeschreibung siehe Perl-Dokumentation (perldoc -f seek).
tell() - Liefere Position in Datei
Synopsis
$pos = $fh->tell;
Description
Liefere die Position der Filehandle in der Datei. Genaue Funktionsbeschreibung siehe Perl-Dokumentation (perldoc -f tell).
Sperren
lock() - Sperre Datei
Synopsis
$fh->lock($lockMode);
Description
Locke die Datei im Lock-Modus $lockMode. Die Methode liefert keinen Wert zurück.
Folgende Lockmodes werden unterschieden:
- 'SH'
-
shared lock
- 'EX'
-
exclusive lock
- 'SHNB'
-
shared lock, non-blocking
- 'EXNB'
-
exclusive lock, non-bloking
Liefere "wahr", wenn der Lock gesetzt werden kann, im Fehlerfall liefere "falsch".
unlock() - Hebe Sperre auf
Synopsis
$fh->unlock;
Description
Hebe Sperre auf Dateihandle $fh auf. Die Methode liefert keinen Wert zurück.
Encoding
setEncoding() - Setze Encoding
Synopsis
$fh = $fh->setEncoding($encoding);
Arguments
Returns
FileHandle-Objekt (für Method-Chaining)
Description
Definiere für Filehandle $fh das Encoding $encoding. D.h. alle Daten werden automatisch gemäß diesem Encoding beim Schreiben encodiert bzw. beim Lesen dekodiert.
Verschiedenes
autoFlush() - Schalte Filehandle in ungepufferten Modus
Synopsis
$fh->autoFlush;
$fh->autoFlush($bool);
binmode() - Aktiviere Binärmodus oder Layer
Synopsis
$fh->binmode;
$fh->binmode($layer);
Description
Schalte Filehandle in Binärmodus oder setze Layer $layer. Genaue Funktionsbeschreibung siehe Perl-Dokumentation (perldoc -f binmode).
Klassenmethoden
captureStderr() - Fange STDERR ab
Synopsis
$class->captureStderr(\$str);
Returns
Die Methode liefert keinen Wert zurrück
Description
Fange alle Ausgaben auf STDERR ab und lenke sie auf Skalarvariable $str um.
slurpFromStdin() - Lies Eingaben von STDIN
Synopsis
$data = $class->slurpFromStdin;
Returns
String
Description
Lies alle Eingaben von STDIN und liefere diese als eine Zeichenkette zurück.
VERSION
1.220
AUTHOR
Frank Seitz, http://fseitz.de/
COPYRIGHT
Copyright (C) 2024 Frank Seitz
LICENSE
This code is free software; you can redistribute it and/or modify it under the same terms as Perl itself.