-
Notifications
You must be signed in to change notification settings - Fork 1
/
empresas.php
65 lines (60 loc) · 1.92 KB
/
empresas.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
<?php
/*
Script para processamento dos dados das empresas dos arquvios CSV do CNPJ da receita federal
(C) 2023 - Renato Monteiro Batista
https://github.com/renatomb/cnpj2sql
*/
require_once("funcoes.php");
// Abrir o arquivo CSV empresas.csv
$handle = fopen($argv[1] . ".csv", "r");
// Abrir o arquivo SQL para gravacao acrescentando os dados ao final do arquivo
// Nome do arquivo sera passado por parametro
$gravacao = fopen($argv[1] . ".sql", "a");
$contador_sql=0;
$inicio_query="REPLACE INTO empresas (cnpj_basico, razao_social, natureza_juridica, qualif_juridica, capital_social, porte, ente_federativo_responsavel) VALUES ";
// Ler o arquivo linha por linha e mostrar na tela
if ($handle) {
while (($line = fgets($handle)) !== false) {
// separar os campos por ;
$campos = explode('";"', $line);
for ($i=0;$i<count($campos);$i++) {
$campos[$i] = remove_aspas($campos[$i]);
if (($i == 1) || ($i == 6)) {
$campos[$i] = aspas($campos[$i]);
}
if ($i == 4) {
// Trocar virgula por ponto no capital social
$campos[$i] = troca_virgula_ponto($campos[$i]);
}
}
// Tratamento dos casos onde o porte está vazio
$campos[5] = vazio_null($campos[5]);
if ($contador_sql == 0) {
// Iniciar a query
$query = $inicio_query . "(" . implode(",", $campos) . ")";
}
else {
// Continuar a query
$query .= ", (" . implode(",", $campos) . ")";
}
$contador_sql++;
if ($contador_sql == 1000) {
// Gravar no arquivo SQL
fwrite($gravacao, $query . ";\n");
echo ".";
$contador_sql=0;
}
}
if ($contador_sql > 0) {
// Gravar no arquivo SQL
fwrite($gravacao, $query . ";\n");
echo "M";
}
// Fechar os arquivos
fclose($handle);
fclose($gravacao);
}
else {
die("erro abrindo o arquivo " . $argv[1] . "\n");
}
?>