Vor kurzem haben wir mehrere gängige Methoden zum Lesen von Dateien in PHP aussortiert und uns einige Codes angesehen, wie folgt:
Sie können fopen und file_get_contentsEs gibt keinen wesentlichen Unterschied zwischen diesen beiden Funktionen, außer dass der PHP-Code der ersteren zum Lesen von Dateien etwas komplizierter ist als der der letzteren.
<?php $file_name = "1.txt"; echo $file_name . ""; $fp = fopen($file_name, 'r'); //$buffer=fgets($fp); while (!feof($fp)) { $buffer = fgets($fp); echo $buffer; } fclose($fp); ?>
1.fread
string fread ( int $handle , int $length )
fread() liest bis zur Länge Bytes aus der Datei, auf die das Handle zeigt. 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); ?>
<?php $handle = fopen('http://www.baidu.com', 'r'); $content = ''; while(!feof($handle)){ $content .= fread($handle, 8080); } echo $content; fclose($handle); ?>
<?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); ?>
3.fgetss
string fgetss ( Ressource $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 ]] )
<?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 einem Fehler FALSE zurück und zeigt eineFehlermeldung an, es sei denn, es wird als @readfile() aufgerufen.
<?php $size = readfile('./file.txt'); echo $size; ?>
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 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 ( resources $handle )
Ändern Sie den angegebenen Dateizeiger von The Die aktuelle Position wird in EOF gelesen und das Ergebnis 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 einmehrdimensionales Array, einschließlich des Namens und der Einstellungen jedes Abschnitts in der Konfigurationsdatei. 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 der INI-Datei verwendet werden. einschließlich: null, ja, nein, wahr und falsch. Die Werte null, nein und falsch sind äquivalent zu „“, und die Werte ja und wahr sind äquivalent zu „1“. [()“ kann auch nicht irgendwo im Schlüsselnamen verwendet werden, und diese Zeichen haben im Optionswert eine besondere Bedeutung.
Ein paar Hinweise:
1. Ermutigen Sie die Verwendung des b-Flags bei der Verarbeitung von Binärdateien, auch wenn das System dies nicht erfordert, da dies das Skript beeinträchtigen kann tragbarer.
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.
Das obige ist der detaillierte Inhalt vonZusammenfassung der Anwendungsbeispiele von Funktionen zum Lesen von Dateien in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!