Función fgetcsv
La función fgetcsv lee una línea de un archivo y la analiza en campos con formato CSV. El primer parámetro de la función acepta un puntero a un archivo abierto, el segundo - la longitud máxima de la línea, el tercero - el separador de campos (por defecto coma), el cuarto - el carácter delimitador (por defecto comillas dobles), el quinto - el carácter de escape.
Sintaxis
fgetcsv(
resource $handle,
int $length = 0,
string $separator = ",",
string $enclosure = "\"",
string $escape = "\"
);
Ejemplo
Leamos un archivo CSV línea por línea y mostremos el contenido:
<?php
$file = fopen('data.csv', 'r');
while (($row = fgetcsv($file)) !== false) {
print_r($row);
}
fclose($file);
?>
Resultado de la ejecución del código para un archivo con contenido "a,b,c":
['a', 'b', 'c']
Ejemplo
Lectura de CSV especificando la longitud máxima de línea y un separador personalizado:
<?php
$file = fopen('data.csv', 'r');
while (($row = fgetcsv($file, 1000, ';')) !== false) {
print_r($row);
}
fclose($file);
?>
Resultado de la ejecución del código para un archivo con contenido "a;b;c":
['a', 'b', 'c']
Ejemplo
Lectura de CSV con comillas y escape:
<?php
$file = fopen('data.csv', 'r');
while (($row = fgetcsv($file, 0, ',', '"', '\')) !== false) {
print_r($row);
}
fclose($file);
?>
Resultado de la ejecución del código para un archivo con contenido '"a,b",c,"d\"e"':
['a,b', 'c', 'd"e']