Мне нужно преобразовать координаты долготы и широты в любую страну или город, есть ли пример этого в python?
заранее спасибо!
Мне нужно преобразовать координаты долготы и широты в любую страну или город, есть ли пример этого в python?
заранее спасибо!
Я использую API Google.
from urllib2 import urlopen
import json
def getplace(lat, lon):
url = "http://maps.googleapis.com/maps/api/geocode/json?"
url += "latlng=%s,%s&sensor=false" % (lat, lon)
v = urlopen(url).read()
j = json.loads(v)
components = j['results'][0]['address_components']
country = town = None
for c in components:
if "country" in c['types']:
country = c['long_name']
if "postal_town" in c['types']:
town = c['long_name']
return town, country
print(getplace(51.1, 0.1))
print(getplace(51.2, 0.1))
print(getplace(51.3, 0.1))
Вывод:
(u'Hartfield', u'United Kingdom')
(u'Edenbridge', u'United Kingdom')
(u'Sevenoaks', u'United Kingdom')
Это называется обратным геокодированием. В Python есть одна библиотека, которая сосредоточена на этом: https://github.com/thampiman/reverse-geocoder
Некоторые связанные вопросы с другими идеями:
В целом API Google - лучший подход. Это не подходит для моего случая, так как мне пришлось обрабатывать много записей, а api медленный.
Я закодировал небольшую версию, которая делает то же самое, но сначала загружает огромную геометрию и вычисляет страны на машине.
import requests
from shapely.geometry import mapping, shape
from shapely.prepared import prep
from shapely.geometry import Point
data = requests.get("https://raw.githubusercontent.com/datasets/geo-countries/master/data/countries.geojson").json()
countries = {}
for feature in data["features"]:
geom = feature["geometry"]
country = feature["properties"]["ADMIN"]
countries[country] = prep(shape(geom))
print(len(countries))
def get_country(lon, lat):
point = Point(lon, lat)
for country, geom in countries.iteritems():
if geom.contains(point):
return country
return "unknown"
print(get_country(10.0, 47.0))
# Austria