-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcoding_location.js
More file actions
99 lines (91 loc) · 2.46 KB
/
coding_location.js
File metadata and controls
99 lines (91 loc) · 2.46 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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
var fs = require('fs');
var parse = require('csv-parse');
var node_geo = require('node-geocoder');
//var sleep = require('sleep')
var csvData=[];
var latDict={};
var longDict={};
var options = {
provider: 'google',
httpAdapter: 'https',
apiKey: 'AIzaSyDodbz5miqqfajSkHMV0PyJ_h89NrdMc24',
formatter: null
};
var geocoder = node_geo(options);
var counter = 0;
var check_counter = 0;
var flag = true;
function getPlace(x) {
geocoder.geocode(x)
.then(function(res) {
var place = res[0];
//console.log(place['latitude']);
latDict[x] = place['latitude'];
//console.log(place['longitude']);
longDict[x] = place['longitude']
check_counter += 1;
})
.catch(function(err) {
console.log(err);
check_counter += 1;
});
}
function sleep(time) {
var stop = new Date().getTime();
while(new Date().getTime() < stop + time) {
;
}
}
fs.createReadStream("VehicleDetails.csv")
.pipe(parse({delimiter: ','})) // parsed the data from VehicleDetails
.on('data', function(csvrow) {
console.log(csvrow);
csvData.push(csvrow);
})
.on('end',function() {
console.log("getting data from geocoder");
for (var i = 1; i< csvData.length; i++) {
var csvrow = csvData[i];
var datum = csvrow[19];
var x = datum.split(" - ");
x = x[1]+" "+x[0];
if (x in latDict) {
console.log(latDict[x]);
console.log(longDict[x]);
sleep(30);
} else {
//console.log(datum);
console.log(x);
getPlace(x);
sleep(30);
}
}
//console.log(csvData);
flag = false;
});
function update() {
if(flag) {
setTimeout(update, 3000);
return;
}
var i=0;
var data = "";
//console.log(csvData);
csvData.forEach(function(csvrow) {
if (i == 0) {
csvrow += ["Latitude", "Longitude"];
i+=1;
} else {
var datum = csvrow[19];
var x = datum.split(" - ");
x = x[1]+" "+x[0];
csvrow += [latDict[x], longDict[x]]
}
data += csvrow+"\n";
});
fs.writeFile("works.csv", data, function(err) {
console.log(err);
});
console.log("works.csv has been saved.")
}
setTimeout(update, 5000)