Heim > Artikel > Backend-Entwicklung > PHP-Methodencode zum Lesen von Dateien
Ich habe verschiedene Methoden zum Lesen von Dateien in PHP zusammengestellt, um sie in Zukunft leichter nachschlagen zu können.
1.frea,
string fread ( int $handle , int $length )
fread() liest bis zur Länge aus der Datei, auf die das Handle zeigt Byte. Diese Funktion wird aufgerufen, nachdem die maximale Länge von Bytes gelesen wurde oder wenn EOF erreicht ist oder (für Netzwerk-Streams) wenn ein Paket verfügbar ist oder (nach dem Öffnen eines User-Space-Streams) 8192 Bytes gelesen wurden. abhängig davon, welcher Zustand zuerst auftritt.
fread() gibt die gelesene Zeichenfolge oder FALSE zurück, wenn ein Fehler auftritt.
<?php $filename = "/usr/local/something.txt"; $handle = fopen($filename, "r");//读取二进制文件时,需要将第二个参数设置成'rb' //通过filesize获得文件大小,将整个文件一下子读到一个字符串中 $contents = fread($handle, filesize ($filename)); fclose($handle); ?>
Wenn es sich bei der zu lesenden Datei nicht um eine lokale gewöhnliche Datei, sondern um eine Remote-Datei oder Stream-Datei handelt, kann diese Methode nicht verwendet werden, da filesize die Größe dieser Dateien nicht ermitteln kann. Zu diesem Zeitpunkt müssen Sie den Rückgabewert von feof () oder fread () verwenden, um festzustellen, ob das Ende der Datei gelesen wurde.
Zum Beispiel:
<?php $handle = fopen('http://www.baidu.com', 'r'); $content = ''; while(!feof($handle)){ $content .= fread($handle, 8080); } echo $content; fclose($handle); ?>
oder:
<?php $handle = fopen('http://www.baidu.com', 'r'); $content = ''; while(false != ($a = fread($handle, 8080))){//返回false表示已经读取到文件末尾 $content .= $a; } echo $content; fclose($handle); ?>
2.fgets
string fgets ( int $handle [, int $length ] )
fgets() liest eine Zeile aus der Datei, auf die das Handle zeigt, und gibt einen String mit einer Länge von höchstens 1 Byte zurück. Stoppt, wenn ein Zeilenumbruchzeichen (im Rückgabewert enthalten), ein EOF oder eine Länge von 1 Byte gelesen wurde (je nachdem, was zuerst eintritt). Wenn die Länge nicht angegeben ist, beträgt sie standardmäßig 1 KB oder 1024 Byte.
<?php $handle = fopen('./file.txt', 'r'); while(!feof($handle)){ echo fgets($handle, 1024); } fclose($handle); ?>
Hinweis: Der Längenparameter ist ab PHP 4.2.0 optional. Wenn er weggelassen wird, wird angenommen, dass die Länge der Zeile 1024 beträgt. Ab PHP 4.3 führt das Weglassen der Länge zum Lesen aus dem Stream bis zum Ende der Zeile. Wenn die meisten Zeilen in der Datei größer als 8 KB sind, ist die Angabe der maximalen Zeilenlänge im Skript effizienter bei der Ressourcennutzung. Ab PHP 4.3 kann diese Funktion sicher mit Binärdateien verwendet werden. Frühere Versionen taten dies nicht.
3.fgetss
string fgetss ( resources $handle [, int $length [, string $allowable_tags ]] )
Die gleiche Funktion wie fgets, aber fgetss wird es versuchen Zum Anfang Entfernen Sie alle HTML- und PHP-Tags aus dem gelesenen Text. Mit dem optionalen dritten Parameter können Sie angeben, welche Tags nicht entfernt werden sollen.
<?php $handle = fopen('./file.txt', 'r'); while(!feof($handle)){ echo fgetss($handle, 1024, '<br>'); } fclose($handle); ?>
4.file
Array-Datei ( string $filename [, int $use_include_path [, resources $context ]] )
Lesen Sie den Dateiinhalt in ein Array , jedes Element im Array entspricht einer Zeile in der Datei, einschließlich Zeilenumbrüchen. Sie können die Funktion rtrim() verwenden, um Zeilenumbruchzeichen herauszufiltern, wenn Zeilenabschlusszeichen nicht erforderlich sind.
<?php $a = file('./file.txt'); foreach($a as $line => $content){ echo 'line '.($line + 1).':'.$content; } ?>
5.readfile
int readfile ( string $filename [, bool $use_include_path [, resources $context ]] )
Eine Datei lesen und in die schreiben Ausgabepuffer. Gibt die Anzahl der aus der Datei gelesenen Bytes zurück. Gibt bei Fehler FALSE zurück und zeigt eine Fehlermeldung an, es sei denn, es wird als @readfile() aufgerufen.
<?php $size = readfile('./file.txt'); echo $size; ?>
6.file_get_contents
string file_get_contents ( string $filename [, bool $use_include_path [, resources $context [, int $offset [, int $maxlen ]]]] )
Lesen Sie die Datei in einen String ein. Der dritte Parameter $context kann zum Festlegen einiger Parameter verwendet werden, z. B. zum Festlegen eines Zeitlimits beim Zugriff auf Remote-Dateien usw.
Darüber hinaus hat file_get_contents eine viel bessere Leistung als die oben genannten Funktionen, daher sollte file_get_contents Priorität erhalten. Aber readfile scheint eine bessere Leistung zu haben als file_get_contents (?), da fopen nicht aufgerufen werden muss.
<?php $ctx = stream_context_create(array( 'http' => array( 'timeout' => 1 //设置超时 ) ) ); echo file_get_contents("http://www.baidu.com/", 0, $ctx); ?>
7.fpassthru
int fpassthru ( Ressource $handle )
Lesen Sie den angegebenen Dateizeiger von der aktuellen Position zum EOF und schreiben Sie das Ergebnis in den Ausgabepuffer.
<?php header("Content-Type:text/html;charset=utf-8"); $handle = fopen('./test2.php', 'r'); fseek($handle, 1024);//将指针定位到1024字节处 fpassthru($handle); ?>
8.parse_ini_file
array parse_ini_file ( string $filename [, bool $process_sections ] )
parse_ini_file() lädt eine durch den Dateinamen angegebene INI-Datei und gibt sie zurück die Einstellungen als assoziatives Array. Wenn Sie den letzten Parameter „process_sections“ auf TRUE setzen, erhalten Sie ein mehrdimensionales Array, das den Namen und die Einstellungen jedes Abschnitts in der Konfigurationsdatei enthält. Der Standardwert für „process_sections“ ist FALSE.
Hinweis:
1. Wenn der Wert in der INI-Datei nicht alphanumerische Zeichen enthält, muss er in doppelte Anführungszeichen gesetzt werden (").
2. Einige reservierte Wörter können nicht verwendet werden als ini Schlüsselnamen in der Datei, einschließlich: null, ja, nein, wahr und falsch sind äquivalent zu „“, Werte von ja und wahr sind äquivalent zu „1“. ()“ kann auch nirgendwo in einem Schlüsselnamen verwendet werden, und diese Zeichen haben in Optionswerten eine besondere Bedeutung.
Inhalt der test.ini-Datei:
; Dies ist eine Beispielkonfigurationsdatei
; Kommentare beginnen mit „;“, wie in php.ini
[first_section]one = 1five = 5animal = BIRD [second_section]path = "/usr/local/bin"URL = "http://www.example.com/~username
test.php Inhalt:
<?php $config = parse_ini_file('./test.ini', ture); print_r($config);?>
Ausgabeinhalt:
Array ( [first_section] => Array ( [one] => 1 [five] => 5 [animal] => BIRD ) [second_section] => Array ( [path] => /usr/local/bin [URL] => http://www.example.com/~username ) )
Einige Hinweise:
1 Es wird empfohlen, bei der Verarbeitung von Binärdateien das b-Flag zu verwenden, auch wenn Das System funktioniert nicht. Ja, dadurch wird das Skript portabler.
2. Die Option „allow_url_fopen“ aktiviert die URL-Form des fopen-Kapselungsprotokolls, sodass auf URL-Objekte wie Dateien zugegriffen werden kann. Das Standard-Kapselungsprotokoll ermöglicht den Zugriff auf Remote-Dateien mithilfe der FTP- und http-Protokolle. Einige Erweiterungsbibliotheken wie zlib registrieren möglicherweise weitere Kapselungsprotokolle. Aus Sicherheitsgründen kann diese Option nur in der php.ini gesetzt werden.
3. Wenn Sie eine URL mit Sonderzeichen (z. B. Leerzeichen) öffnen möchten, müssen Sie urlencode() für die URL-Kodierung verwenden.
Verwandte Empfehlungen:
Detaillierte Erläuterung der drei Methoden zum Lesen von Dateien in PHP
Eine Zusammenfassung von Beispielen für die Verwendung von Funktionen in PHP zum Lesen von Dateien
php Zusammenfassung von fünf Methoden zum Lesen von Dateien
Das obige ist der detaillierte Inhalt vonPHP-Methodencode zum Lesen von Dateien. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!