Maison > développement back-end > tutoriel php > Code de méthode PHP pour lire des fichiers

Code de méthode PHP pour lire des fichiers

小云云
Libérer: 2023-03-20 15:46:01
original
3961 Les gens l'ont consulté

J'ai trié plusieurs méthodes de lecture de fichiers en PHP pour une référence facile à l'avenir. J'espère que cela pourra aider tout le monde.

1.frea,

string fread ( int $handle , int $length )

fread() lit jusqu'à la longueur du fichier pointé par handle octet. 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 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);
?>
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 octet. 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 ( resource $handle [, int $length [, string $allowable_tags ]] )

La même fonction que fgets, mais fgetss essaiera pour commencer Supprimez 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 [, resource $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 ]]]] )

Lisez 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); 
?>
Copier après la connexion

7.fpassthru

int fpassthru ( resource $handle )

Lisez le pointeur de fichier donné de la position actuelle vers EOF et écrivez le résultat 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. les 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 (").
2. Certains mots réservés ne peuvent pas être utilisés. comme ini Noms de clés dans le fichier, notamment : null, yes, no, true et false. Les valeurs de null, no et false sont équivalentes à "", les valeurs de yes et true sont équivalentes à "1". ()" ne peut pas non plus être utilisé nulle part dans un nom de clé, et ces caractères ont une signification particulière dans les valeurs d'option.
Contenu du fichier test.ini :

 ; Ceci est un exemple de fichier de configuration
 ; Les commentaires commencent par ';', comme dans php.ini

[first_section]one = 1five = 5animal = BIRD
[second_section]path = "/usr/local/bin"URL = "http://www.example.com/~username
Copier après la connexion

test.php Contenu :

<?php    
 $config = parse_ini_file(&#39;./test.ini&#39;, ture);   
  print_r($config);?>
Copier après la connexion

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
        )
)
Copier après la connexion

Quelques notes :

1 Il est encouragé à utiliser l'indicateur b lors du traitement de fichiers binaires, même si. le système ne le fait pas Oui, cela rend 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.

Recommandations associées :

Explication détaillée des trois méthodes de lecture de fichiers en php

Un résumé d'exemples d'utilisation de fonctions en php pour lire des fichiers

php Résumé de cinq méthodes de lecture de fichiers

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