Geolocation
How to geo-reference your dataset
@JacopoOttaviani
Geocoding is the process of converting addresses (like "Puerta del Sol, Madrid") into geographic coordinates (like latitude 40.416980 and longitude -3.704429), which you can use to place markers on a map.
Scenarios
-
Location columns are lat/lon
-
Location column is a city
-
Location column is a postal code
-
Location column is a province, region or country
-
Location column is an address
Scenarios, i
-
Location columns are lat/lon (free on CartoDB)
-
Location column is a city (free on CartoDB)
-
Location column is a postal code (free on CartoDB)
-
Location column is a province, region or country
-
Location column is an address
Scenarios, ii
-
Location columns are lat/lon (free on CartoDB)
-
Location column is a city (free on CartoDB)
-
Location column is a postal code (free on CartoDB)
-
Location column is a province, region or country (choropleth: shapefile merging required)
-
Location column is an address
Scenarios, iii
-
Location columns are lat/lon (free on CartoDB)
-
Location column is a city (free on CartoDB)
-
Location column is a postal code (free on CartoDB)
-
Location column is a province, region or country (choropleth: shapefile merging required)
-
Location column is an address (100 for free on CartoDB. Otherwise: workaround required).
When for free:
data:image/s3,"s3://crabby-images/d2cb5/d2cb56845eded81c979767ab54cb99f0d02e0711" alt=""
More info: http://docs.cartodb.com/tutorials/how_to_georeference.html
When it is not for free, or it doesn't work...
1st option (easy):
- Use Google Maps API in Google Spreadsheet with a macro script
2nd option (nerdy):
- Use OpenRefine to geocode your data with Google and OpenStreetMap API
- Open the dataset you want to georeference on OpenRefine
- Fetch the geographic information from a geographic API
- Fill it in the dataset and re-import in CartoDB
data:image/s3,"s3://crabby-images/044b2/044b2cf42f2acd3791650c90689a42686e9a3c23" alt=""
data:image/s3,"s3://crabby-images/75f5b/75f5b94071bc5441fa7049058933f9a12ac8ef2c" alt=""
https://github.com/nuket/google-sheets-geocoding-macro
- Open the Google Spreadsheet you want to geolocate
-
Tools -> Script Editor
-
Copy and paste the code into the editor
-
Save and reload your sheet
-
a new “Geocode” menu should appear after the reload
data:image/s3,"s3://crabby-images/58a4c/58a4cf2eac62114d3762a313a3b832964a79f81b" alt=""
What's an API?
Application Programming Interface
data:image/s3,"s3://crabby-images/774fc/774fc3f119cc5c02f9b228e2fce958b84fd4b181" alt=""
It's just a different way to query a web application, such as Google Maps.
How? With a URL:
http://maps.googleapis.com/maps/api/geocode/json?sensor=false&address=the_address_im_looking_for
for example:
http://maps.googleapis.com/maps/api/geocode/json?sensor=false&address=puerta del sol madrid
JSON result returned by the API
(It's like a blob of data with geographic info)
data:image/s3,"s3://crabby-images/a289c/a289c5b172d4950968eec9310903b3d7d1ae73a4" alt=""
data:image/s3,"s3://crabby-images/0ef80/0ef8055bc19489185baecd16039fdab0b3000045" alt=""
Let's be a little bit more nerdish with OpenRefine
www.openrefine.org
OpenRefine
Open the dataset: 90_non_geolocated_libya_body_count
data:image/s3,"s3://crabby-images/81fb1/81fb1545c78329533eca914ebee1cdd87d9619f3" alt=""
Coordinates extraction
Once queried the Google Maps API, we can extract the coordinates from the API blobs
data:image/s3,"s3://crabby-images/45ac7/45ac7cbd33d38d5603d6ba35df709db0d464f054" alt=""
Finally you have your coordinates
- Check empty/error rows
- Remove the columns you don't need
- Export the dataset in CSV or XLS format
- Open your new dataset on CartoDB
- Map it!
When the API doesn't find the coordinates, go manual
data:image/s3,"s3://crabby-images/4fcbe/4fcbec9d01e29ae021e716e17351b494f55f2bfa" alt=""
Geolocation via OpenRefine
Step-by-step guide:
http://bit.ly/openrefine-geolocation
Questions?
Exercise #4. Geolocation with OpenRefine
-
Download dataset: 90_libya_body_count from http://bit.ly/cartography-madrid
-
Georeference it with OpenRefine
- Use Google Maps Geolocation API
- Extract coordinates from blobs
- Remove blobs
-
Export the new dataset
-
Import it on CartoDB and check the geometry
#4 - Geolocation
By jottaviani
#4 - Geolocation
- 797