Maison  >  Article  >  développement back-end  >  Résumé des méthodes courantes de lecture de fichiers en PHP

Résumé des méthodes courantes de lecture de fichiers en PHP

墨辰丷
墨辰丷original
2018-06-02 09:14:131395parcourir

Cet article présente principalement un résumé des méthodes courantes de lecture de fichiers en PHP. Les amis intéressés peuvent s'y référer. J'espère qu'il sera utile à tout le monde.

1.fread

string fread ( int $handle , int $length )

fread() points du handle Lit jusqu'à la longueur maximale d'octets du fichier. 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 avoir ouvert 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 se produit.

<?php
  $filename = "/usr/local/something.txt";
  $handle = fopen($filename, "r");//读取二进制文件时,需要将第二个参数设置成&#39;rb&#39;
  
  //通过filesize获得文件大小,将整个文件一下子读到一个字符串中
  $contents = fread($handle, filesize ($filename));
  fclose($handle);
?>

Si le fichier à lire n'est pas un fichier ordinaire local, mais un fichier distant ou un fichier de flux, cette méthode ne peut pas être utilisée, car filesize ne peut pas obtenir la taille de ces 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);
?>

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);
?>

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);
?>

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 faisaient 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);
?>

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;
  }
?>

5.readfile

int readfile ( string $filename [, bool $use_include_path [, ressource $context ]] )

Lire dans 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;
?>

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 utilisé en premier. 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); 
?>

7.fpassthru

int fpassthru ( resource $handle )

Modifie le pointeur de fichier donné de 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);
?>

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 paramètre final process_sections sur TRUE, vous obtiendrez un tableau multidimensionnel contenant 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 doubles. (").

2. Certains mots réservés ne peuvent pas être utilisés comme noms de clés dans les fichiers ini, notamment : null, yes, no, true et false. Les valeurs​​sont null, no et false sont équivalent à "", la valeur Equivalent à "1" pour oui et vrai. Les caractères {}|&~![()" ne peuvent être utilisés nulle part dans les noms de clé, et ces caractères ont une signification particulière dans les valeurs d'option.

Contenu du fichier test.ini :

; This is a sample configuration file
; Comments start with &#39;;&#39;, as in php.ini

[first_section]
one = 1
five = 5
animal = BIRD

[second_section]
path = "/usr/local/bin"
URL = "http://www.example.com/~username

Contenu du test.php :

<?php 
  $config = parse_ini_file(&#39;./test.ini&#39;, ture);
  print_r($config);
?>

Contenu de sortie :

Array
(
  [first_section] => Array
    (
      [one] => 1
      [five] => 5
      [animal] => BIRD
    )

  [second_section] => Array
    (
      [path] => /usr/local/bin
      [URL] => http://www.example.com/~username
    )

)

Quelques notes :

1. Il est encouragé à utiliser 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. Le protocole d'encapsulation par défaut permet d'accéder aux fichiers distants à l'aide des protocoles ftp et http. 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.

Résumé : Ce qui précède représente l'intégralité du contenu de cet article, j'espère qu'il sera utile à l'étude de chacun.

Recommandations associées :

phpComment déterminer si un utilisateur suit un compte public WeChat

Détaillé explication des exemples de paiement PHP WeChat

Méthodes magiques et constantes magiques en PHP

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!

Déclaration:
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