-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsocio.php
More file actions
84 lines (79 loc) · 2.64 KB
/
Copy pathsocio.php
File metadata and controls
84 lines (79 loc) · 2.64 KB
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
<?php
/*
Script para processamento dos dados dos socios 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 .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","identificador_socio","nome_socio","cnpj_socio","cod_qualificacao_socio","data_entrada_sociedade","perc_capital_social","cpf_representante_legal","nome_representante_legal","cod_qualificacao_representante_legal","desconhecido","cpf_socio_mascarado");
$inicio_query="REPLACE INTO socio (" . 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<11;$i++) {
$campos[$i] = remove_aspas($entrada[$i]);
// Tratamento dos campos com texto
if ((in_array($i, array(2,8,10)))) {
$campos[$i] = aspas($campos[$i]);
}
// Tratamento do campo cnpj/cpf do socio
if ($i == 3) {
if (strlen($campos[$i]) == 11) {
// CPF
$campos[11] = vazio_null($campos[$i]);
$campos[$i] = "NULL";
}
else {
// CNPJ
$campos[$i] = vazio_null($campos[$i]);
$campos[11] = "NULL";
}
}
// Tratamento das datas
if ((in_array($i, array(5)))) {
$campos[$i] = data_sql($campos[$i]);
}
// Tratamento dos campos numéricos
if ((in_array($i, array(0,1,4,6,7,9)))) {
$campos[$i] = vazio_null($campos[$i]);
}
}
if ($contador_sql == 0) {
// ordenar os campos
ksort($campos);
// 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 "O";
$contador_sql=0;
}
}
if ($contador_sql > 0) {
// Gravar no arquivo SQL
fwrite($gravacao, $query . ";\n");
echo ".";
}
// Fechar os arquivos
fclose($handle);
fclose($gravacao);
}
else {
die("erro abrindo o arquivo " . $argv[1] . "\n");
}
?>