-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathgenerate-json-from-csv.js
98 lines (83 loc) · 2.69 KB
/
generate-json-from-csv.js
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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
var csv = require("fast-csv"),
fs = require("fs"),
iconvlite = require('iconv-lite'),
path = require("path"),
util = require("util");
// constant of version
var version = "19.2.B";
// constant of states
var states = ["ac", "al", "am", "ap", "ba", "ce", "df", "es", "go", "ma", "mg",
"ms", "mt", "pa", "pb", "pe", "pi", "pr", "rj", "rn", "ro", "rr",
"rs", "sc", "se", "sp", "to"
];
// converts date to ISO date format
var toISOString = function (date) {
var a = date.split('/');
return a[2] + "-" + a[1] + "-" + a[0];
};
// converts the data from csv from
// portuguese fields to english fields
var toEnglish = function (state, data) {
var fiscalType = '';
switch (data.tipo.toString()) {
case '0':
fiscalType = 'ncm';
break;
case '1':
fiscalType = 'nbs';
break;
case '2':
fiscalType = 'lc116';
break;
}
return {
fiscalType: fiscalType,
state: state,
source: data.fonte,
version: data.versao,
code: data.codigo,
effectiveDate: toISOString(data.vigenciainicio),
federalNationalRate: parseFloat(data.nacionalfederal),
federalImportedRate: parseFloat(data.importadosfederal),
stateRate: parseFloat(data.estadual),
municipalRate: parseFloat(data.municipal)
};
};
// writes the json file based on the data
var writeFile = function (data) {
var path = util.format('%s/%s/%s.json', data.fiscalType, data.state, data.code);
fs.writeFileSync(path, iconvlite.encode(JSON.stringify(data), 'UTF-8'));
};
states.forEach(function (state) {
// create folders to json files
fs.mkdir("ncm/" + state.toLowerCase(), function (e) {});
fs.mkdir("nbs/" + state.toLowerCase(), function (e) {});
fs.mkdir("lc116/" + state.toLowerCase(), function (e) {});
var fileName = "raw-data/TabelaIBPTax" + state.toUpperCase() + version + ".csv";
console.log("Processing file " + fileName);
var readStream = fs.createReadStream(fileName)
.pipe(iconvlite.decodeStream('ISO-8859-1'));
csv.fromStream(readStream, {
headers: ["codigo", "ex", "tipo", "descricao",
"nacionalfederal", "importadosfederal",
"estadual", "municipal", "vigenciainicio",
"vigenciafim", "chave", "versao", "fonte"
],
quoteColumns: false,
ignoreEmpty: true,
quote: null,
delimiter: ';'
})
.on("error", function (err) {
console.error("ERROR: Parsing file " + fileName, err);
})
.on("data", function (data) {
// we only need to process the types
if (data.tipo != 1 && data.tipo != 0 && data.tipo != 2)
return;
writeFile(toEnglish(state, data));
})
.on("end", function () {
console.log("Processed file " + fileName);
});
}); // end of state