Processar um arquivo CSV (PHP)

Como Ler um arquivo CSV utilizando a linguagem de

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

Dúvidas? Faça um comentário logo abaixo ou envie uma mensagem clicando aqui.

O seu endereço de e-mail não será publicado. Campos obrigatórios são marcados com *