forked from dmsza/json2kml
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathjson2kml.py
52 lines (40 loc) · 1.76 KB
/
json2kml.py
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
#####################################################################################
# Python script to convert Google Maps JSON file to a KML file
# Copyright (C) 2017 Dimitri Souza
# https://github.com/dmrsouza/json2kml
#####################################################################################
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License v3 as published by
# the Free Software Foundation.
#####################################################################################
import json
import simplekml
import sys
import codecs
inputFile = "Saved Places.json"
outputFile = "Saved Places.kml"
# JSON Encoding is UTF-8. Change stdout to UTF-8 to prevent encoding error
# when calling print titles inside the loop
sys.stdout = codecs.getwriter("utf-8")(sys.stdout.detach())
print ('Opening file "'+inputFile+'"')
with open (inputFile) as jsonFile:
data = json.load (jsonFile)
kml = simplekml.Kml ()
kml.document.name = outputFile
count = 0
for place in data["features"]:
if place["type"] == "Feature":
title = place["properties"]["Title"]
print ('Parsing place "'+title+'"')
placeLocation = place["properties"]["Location"]
lon = place["geometry"]["coordinates"][0]
lat = place["geometry"]["coordinates"][1]
if "Address" in placeLocation:
address = placeLocation ["Address"]
else:
address = "N/A"
kml.newpoint (name=title, coords=[(lon,lat)], address=address)
count += 1
print ('Saving file "'+outputFile+'"')
kml.save (outputFile)
print ('Done! Total of '+str(count)+' places saved to the KML file.')