-
Notifications
You must be signed in to change notification settings - Fork 1
/
simples.php
69 lines (64 loc) · 2.09 KB
/
simples.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
66
67
68
69
<?php
/*
Script para processamento dos dados dos optantes pelo simples nos 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 .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;
$nomes_colunas=array("cnpj_basico","optante_simples","data_opcao_simples","data_exclusao_simples","mei","data_opcao_mei","data_exclusao_mei");
$inicio_query="REPLACE INTO simples (" . implode(",", $nomes_colunas) . ") VALUES ";
// Ler o arquivo linha por linha e mostrar na tela
if ($handle) {
while (($line = fgets($handle)) !== false) {
// separar os campos por ;
$entrada = explode('";"', $line);
for ($i=0;$i<7;$i++) {
$campos[$i] = remove_aspas($entrada[$i]);
// Tratamento do campo de CNPJ
if ($i == 0) {
$campos[$i] = vazio_null($campos[$i]);
}
// Tratamento dos campos sim/nao convertendo para binario
if ((in_array($i, array(1,4)))) {
$campos[$i] = simnao($campos[$i]);
}
// Tratamento dos campos de data que podem ser nulos
if ((in_array($i, array(2,3,5,6)))) {
$campos[$i] = data_sql($campos[$i]);
}
}
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 "I";
}
// Fechar os arquivos
fclose($handle);
fclose($gravacao);
}
else {
die("erro abrindo o arquivo " . $argv[1] . "\n");
}
?>