forked from covid19india/api
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsheet-to-json_raw_data.js
74 lines (57 loc) · 1.59 KB
/
sheet-to-json_raw_data.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
const fs = require('fs');
const drive = require("drive-db");
const SHEET = "1nzXUdaIWC84QipdVGUKTiCSc5xntBbpMpzLm6Si33zk";
const SHEET_RAW_DATA = "od6"
const dir='./'
const filename = '/raw_data.json'
const tabs = {
raw_data: SHEET_RAW_DATA,
};
async function fetchData() {
const data = await Promise.all(
Object.keys(tabs).map(async tab => {
return {
[tab]: await drive({ sheet: SHEET, tab: tabs[tab] })
};
})
);
let mergedData = {};
data.forEach(obj => {
mergedData = { ...mergedData, ...obj };
});
return mergedData;
}
function sortObjByKey(value) {
return (typeof value === 'object') ?
(Array.isArray(value) ?
value.map(sortObjByKey) :
Object.keys(value).sort().reduce(
(o, key) => {
const v = value[key];
o[key] = sortObjByKey(v);
return o;
}, {})
) :
value;
}
async function writeData(data) {
const fileContent = JSON.stringify(sortObjByKey(data),null,"\t");
if (!fs.existsSync(dir)){
fs.mkdirSync(dir);
}
return await fs.writeFileSync(dir+filename, fileContent);;
}
async function task() {
console.log("Fetching data from sheets...");
const data = await fetchData();
console.log("Writing data to json file...");
await writeData(data);
console.log("Opertion completed!");
}
async function main() {
console.log("Running task on start...");
await task();
console.log("Created Json File With Updated Contents");
}
main();
// source https://github.com/reustle/covid19japan/blob/master/scripts/cache-spreadsheet-data/cache-sheet.js , and made the changes accordingly