Résumé des exemples d'utilisation de fonctions de lecture de fichiers en PHP

伊谢尔伦
Libérer: 2023-03-14 08:46:02
original
2852 Les gens l'ont consulté

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, &#39;r&#39;);
//$buffer=fgets($fp);
while (!feof($fp)) {
$buffer = fgets($fp);
echo $buffer;
}
fclose($fp);
?>
Copier après la connexion

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");//读取二进制文件时,需要将第二个参数设置成&#39;rb&#39;
 
 //通过filesize获得文件大小,将整个文件一下子读到一个字符串中
 $contents = fread($handle, filesize ($filename));
 fclose($handle);
?>
Copier après la connexion
Si le fichier à lire n'est pas un fichier ordinaire local, mais un

fichier distant ou un fichier stream, cette méthode ne peut pas être utilisée car filesize ne peut pas obtenir la taille de ceux-ci fichiers . À ce stade, vous devez utiliser la valeur de retour de feof() ou fread() pour déterminer si la fin du fichier a été lue.

Par exemple :

<?php
 $handle = fopen(&#39;http://www.baidu.com&#39;, &#39;r&#39;);
 $content = &#39;&#39;;
 while(!feof($handle)){
  $content .= fread($handle, 8080);
 }
 echo $content;
 fclose($handle);
?>
Copier après la connexion
ou :

<?php
 $handle = fopen(&#39;http://www.baidu.com&#39;, &#39;r&#39;);
 $content = &#39;&#39;;
 while(false != ($a = fread($handle, 8080))){//返回false表示已经读取到文件末尾
  $content .= $a;
 }
 echo $content;
 fclose($handle);
?>
Copier après la connexion

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(&#39;./file.txt&#39;, &#39;r&#39;);
 while(!feof($handle)){
  echo fgets($handle, 1024);
 }
 fclose($handle);
?>
Copier après la connexion
Remarque : Le paramètre de longueur est facultatif à partir de PHP 4.2.0, s'il est omis, la longueur de la ligne est supposée être de 1024. À partir de PHP 4.3, l'omission de la longueur continuera la lecture du flux jusqu'à la fin de la ligne. Si la plupart des lignes du fichier font plus de 8 Ko, il est plus efficace de spécifier la longueur maximale des lignes dans le script pour utiliser les ressources. À partir de PHP 4.3, cette fonction peut être utilisée en toute sécurité avec des fichiers binaires. Les versions antérieures ne le font pas.

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(&#39;./file.txt&#39;, &#39;r&#39;);
 while(!feof($handle)){
  echo fgetss($handle, 1024, &#39;<br>&#39;);
 }
 fclose($handle);
?>
Copier après la connexion

4.file

fichier tableau ( string $filename [, int $use_include_path [, ressource $context ]] )

Lire le contenu du fichier dans un tableau. Chaque élément du tableau correspond à une ligne du fichier, y compris les nouvelles lignes. Vous pouvez utiliser la fonction rtrim() pour filtrer les caractères de nouvelle ligne lorsque les terminateurs de ligne ne sont pas requis.

<?php
 $a = file(&#39;./file.txt&#39;);
 foreach($a as $line => $content){
  echo &#39;line &#39;.($line + 1).&#39;:&#39;.$content;
 }
?>
Copier après la connexion

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 un

message d'erreur à moins qu'il ne soit appelé comme @readfile().

<?php
 $size = readfile(&#39;./file.txt&#39;);
 echo $size;
?>
Copier après la connexion

6.file_get_contents

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( 
  &#39;http&#39; => array( 
   &#39;timeout&#39; => 1 //设置超时
   ) 
  ) 
 ); 
 echo file_get_contents("http://www.baidu.com/", 0, $ctx); 
?>
Copier après la connexion

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(&#39;./test2.php&#39;, &#39;r&#39;);
 fseek($handle, 1024);//将指针定位到1024字节处
 fpassthru($handle);
?>
Copier après la connexion

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 un

tableau 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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal