Récemment, nous avons trié plusieurs façons courantes de lire des fichiers en PHP et examiné certains codes, comme suit :
Vous pouvez utiliser fopen et file_get_contentsIl n'y a pas de différence essentielle entre ces deux fonctions, sauf que le code PHP de la première pour lire les fichiers est un peu plus compliqué que la seconde.
<?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() lit jusqu'à la longueur des octets du fichier pointé par handle. Cette fonction est appelée après avoir lu jusqu'à une longueur d'octets, ou lorsque EOF est atteint, ou (pour les flux réseau) lorsqu'un paquet est disponible, ou (après l'ouverture d'un flux d'espace utilisateur) 8192 octets ont été lus. Arrêtera de lire le fichier, en fonction de la condition rencontrée en premier. fread() renvoie la chaîne lue, ou FALSE si une erreur survient.<?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() lit une ligne du fichier pointé par handle et renvoie une chaîne d'une longueur maximale de - 1 octets. S'arrête lorsqu'un caractère de nouvelle ligne (inclus dans la valeur de retour), EOF ou une longueur de 1 octet a été lu (selon la première éventualité). Si la longueur n'est pas spécifiée, la valeur par défaut est 1 Ko, soit 1 024 octets.<?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 ]] )
Même fonction que fgets, mais fgetss essaiera de supprimer toutes les balises HTML et PHP du texte lu. Vous pouvez utiliser le troisième paramètre facultatif pour spécifier quelles balises ne doivent pas être supprimées.<?php $handle = fopen('./file.txt', 'r'); while(!feof($handle)){ echo fgetss($handle, 1024, '<br>'); } fclose($handle); ?>
4.file
fichier tableau ( string $filename [, int $use_include_path [, ressource $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 [, ressource $context ]] )
Lire un fichier et écrire dans le tampon de sortie. Renvoie le nombre d'octets lus dans le fichier. Renvoie FALSE en cas d'erreur et affiche unmessage d'erreur à moins qu'il ne soit appelé comme @readfile().
<?php $size = readfile('./file.txt'); echo $size; ?>
string file_get_contents ( string $filename [, bool $use_include_path [, ressource $context [ , int $offset [, int $maxlen ]]]] )
Lire le fichier dans une chaîne. Le troisième paramètre $context peut être utilisé pour définir certains paramètres, tels que la définition du délai d'attente lors de l'accès aux fichiers distants, etc. De plus, file_get_contents a de bien meilleures performances que les fonctions ci-dessus, donc file_get_contents doit être prioritaire. Mais readfile semble avoir de meilleures performances que file_get_contents (?), car il n'a pas besoin d'appeler fopen.<?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)
Modifier le pointeur de fichier donné depuis The la position actuelle est lue dans EOF et le résultat est écrit dans le tampon de sortie.<?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() charge un fichier ini spécifié par nom de fichier et renvoie ses paramètres sous forme de tableau associatif. Si vous définissez le dernier paramètre process_sections sur TRUE, vous obtiendrez untableau multidimensionnel, comprenant le nom et les paramètres de chaque section dans le fichier de configuration. La valeur par défaut de process_sections est FALSE.
Remarque :
1. Si la valeur dans le fichier ini contient des caractères non alphanumériques, elle doit être placée entre guillemets (").
2. Certains mots réservés ne peuvent pas être utilisés comme noms de clé dans le fichier ini, comprenant : null, yes, no, true et false. Les valeurs null, no et false sont équivalentes à "", et les valeurs yes et true sont équivalentes à "1". [()" ne peut pas non plus être utilisé n'importe où dans le nom de la clé, et ces caractères ont une signification particulière dans la valeur de l'option.
Quelques notes :
1. Encouragez l'utilisation de l'indicateur b lors du traitement des fichiers binaires, même si le système ne l'exige pas, cela peut rendre le script plus portable.
2. L'option allow_url_fopen active le formulaire URL du protocole d'encapsulation fopen afin que les objets URL tels que les fichiers soient accessibles. Les protocoles d'encapsulation par défaut fournissent des protocoles FTP et HTTP pour accéder aux fichiers distants. Certaines bibliothèques d'extension telles que zlib peuvent enregistrer davantage de protocoles d'encapsulation. Pour des raisons de sécurité, cette option ne peut être définie que dans le php.ini.
3. Si vous souhaitez ouvrir une URL avec des caractères spéciaux (par exemple, des espaces), vous devez utiliser urlencode() pour l'encodage de l'URL.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!