Dieser Artikel stellt hauptsächlich eine Zusammenfassung gängiger Methoden zum Lesen von Dateien in PHP vor. Ich hoffe, dass er für alle hilfreich ist.
1.fread
string fread ( int $handle , int $length )
fread() zeigt vom Handle Bis zur Länge Bytes aus der Datei lesen. 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 zurück oder FALSE, 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 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 tun dies nicht.
3.fgetss
string fgetss ( resources $handle [, int $length [, string $allowable_tags ]] )
Gleiche Funktion wie fgets, aber fgetss versucht, alle HTML- und PHP-Tags aus dem gelesenen Text zu entfernen. 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 einlesen und in den Ausgabepuffer schreiben. 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 ]]]] )
Liest die Datei in einen String. 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 zuerst verwendet werden. 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 ( resources $handle )
Ändern Sie den angegebenen Dateizeiger vom aktuellen The Die Position wird in EOF gelesen und das Ergebnis wird in den Ausgabepuffer geschrieben.
<?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 ihre Einstellungen als assoziatives Array zurück. 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 als Schlüsselnamen in INI-Dateien verwendet werden, einschließlich: null, ja, nein, wahr und falsch. Die Werte sind null, nein und falsch Äquivalent zu „“, der Wert Äquivalent zu „1“ für „Ja“ und „Wahr“. Die Zeichen {}|&~![()“ können nirgendwo in Schlüsselnamen verwendet werden und diese Zeichen haben in Optionswerten eine besondere Bedeutung.
Inhalt der test.ini-Datei:
; This is a sample configuration file ; Comments start with ';', as in php.ini [first_section] one = 1 five = 5 animal = BIRD [second_section] path = "/usr/local/bin" URL = "http://www.example.com/~username
Inhalt der test.php:
<?php $config = parse_ini_file('./test.ini', ture); print_r($config); ?>
Inhalt der Ausgabe:
Array ( [first_section] => Array ( [one] => 1 [five] => 5 [animal] => BIRD ) [second_section] => Array ( [path] => /usr/local/bin [URL] => http://www.example.com/~username ) )
Ein paar Anmerkungen Zu beachtende Dinge:
1. Es wird empfohlen, das b-Flag bei der Verarbeitung von Binärdateien zu verwenden, auch wenn das System dies nicht erfordert, wodurch das Skript portabler wird.
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.
Zusammenfassung: Das Obige ist der gesamte Inhalt dieses Artikels, ich hoffe, dass er für das Studium aller hilfreich sein wird.
Verwandte Empfehlungen:
phpSo ermitteln Sie, ob ein Benutzer einem öffentlichen WeChat-Konto folgt
Detaillierte Beschreibung Erläuterung der PHP-WeChat-Zahlungsbeispiele
Magische Methoden und magische Konstanten in PHP
Das obige ist der detaillierte Inhalt vonZusammenfassung gängiger Methoden zum Lesen von Dateien in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!