Como Ler um arquivo CSV utilizando a linguagem de programação PHP
Na Primeira linha iremos definir o nome do arquivo:
$name_csv = 'ARQUIVO.csv';
Na sequência declaramos a função “lineStart”:
function lineStart($file) {
$position = ftell($file);
while (fgetc($file) != "\n") {
fseek($file, --$position);
if ($position == 0) break;
}
return $position;
}
A ideia será ler linha por linha do arquivo CSV, porém a cada leitura iremos remover a linha do próprio arquivo. Dessa forma poderemos processar arquivos extensos, com uma grande quantidade de linhas e mesmo que ocorra timeout, poderemos continuar da onde paramos.
Abrimos o arquivo CSV
$file = fopen($name_csv, 'r+');
Apontamos o ponteiro para o final do arquivo (A leitura do CSV será pelo final do arquivo, última linha)
fseek($file, -1, SEEK_END);
Na sequência começamos a leitura do arquivo
while (fstat($file)['size']) {
lineStart($file);
$data = fgetcsv($file);
/* arquivo você irá aplicar a sua lógica */
ftruncate($file, lineStart($file)); /* removemos a linha processada do arquivo CSV */
}
fclose($file);
Script Completo
$name_csv = 'ARQUIVO.csv';
function lineStart($file) {
$position = ftell($file);
while (fgetc($file) != "\n") {
fseek($file, --$position);
if ($position == 0) break;
}
return $position;
}
$file = fopen($name_csv, 'r+');
fseek($file, -1, SEEK_END);
while (fstat($file)['size']) {
lineStart($file);
$data = fgetcsv($file);
/* arquivo você irá aplicar a sua lógica */ ftruncate($file, lineStart($file));
}
fclose($file);