(PHP 4, PHP 5)
fgetcsv — Renvoie la ligne courante et cherche les champs CSV
fgetcsv() est identique à fgets() mais fgetcsv() analyse la ligne qu'il lit et recherche les champs CSV , qu'il va retourner dans un tableau les contenant. Le délimiteur de champs delimiter est la virgule, à moins que vous ne fournissiez un troisième argument.
Note: Le paramètre enclosure a été ajouté en PHP 4.3.0.
handle doit être un pointeur valide, et avoir été correctement ouvert par fopen() , popen() , ou fsockopen() .
length doit être plus grand que la plus grande ligne trouvée dans un fichier CSV (en comptant les caractères de fin de ligne). Il est devenu optionnl en PHP 5.
fgetcsv() retourne FALSE en cas d'erreur, ou en cas de fin du fichier.
Note: Une ligne vide dans un fichier CSV sera retournée sous la forme d'un tableau contenant la valeur NULL et ne sera pas traitée comme une erreur.
Exemple 773. Lit et affiche le contenu d'un fichier CSV avec fgetcsv()
<?php
$row
=
1
;
$handle
=
fopen
(
"test.csv"
,
"r"
);
while ((
$data
=
fgetcsv
(
$handle
,
1000
,
","
)) !==
FALSE
) {
$num
=
count
(
$data
);
echo
"<p> $num fields in line $row: <br /></p>\n"
;
$row
++;
for (
$c
=
0
;
$c
<
$num
;
$c
++) {
echo
$data
[
$c
] .
"<br />\n"
;
}
}
fclose
(
$handle
);
?>
fgetcsv() a été protégé des données binaires depuis PHP 4.3.5.
Note: La définition des locales entre en jeux avec cette fonction. Si LANG vaut, e.g. en_US.UTF-8 , les fichiers encodés sur un octet sont mal lus par cette fonction.