PHP

Processar um arquivo CSV (PHP)

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);
Tags: PHP

Post Recentes

CNPJ alfanumérico Magento 2: módulo grátis com máscara e validação

Módulo gratuito Roger_CnpjAlfanumerico que aplica máscara e validação do novo CNPJ alfanumérico no checkout e formulários do Magento 2 e…

4 dias atrás

CNPJ alfanumérico no WooCommerce: plugin grátis de máscara e validação

A partir de 06/07/2026 a Receita passa a emitir CNPJ alfanumérico. Conheça o plugin grátis que aplica máscara e validação…

4 dias atrás

Como remover um modulo do Magento 2

Para remover um módulo do Magento 2, siga os passos abaixo: 1. Desabilitar o módulo Primeiro, desabilite o módulo usando…

1 ano atrás

Criar um memorando de crédito (cancelar) invoice no Magento 2

Para cancelar 100% do pedido e criar um crédito para todos os itens através da API REST do Magento 2,…

2 anos atrás

Consultando no banco quantidade disponivel para Venda (estoque)

No Magento 2, a quantidade "reservada" na "Salable Quantity" é gerenciada principalmente pelos módulos MSI (Multi-Source Inventory). A "Salable Quantity"…

2 anos atrás

Admin do Magento 2 não acessa

Como corrigir o erro ao acessar o Admin do Magento 2. Mesmo após fazer o login, permanece na tela de…

2 anos atrás