min*_*eow 134 geocoding geolocation geospatial geo
例如,如果我们有这些坐标集
"latitude": 48.858844300000001,
"longitude": 2.2943506,
我们怎样才能找到这个城市/国家?
Mic*_*rdt 169
另外一个选项:
好处:
缺点:
Kev*_*vin 92
免费的Google地理编码API通过HTTP REST API提供此服务.请注意,API是使用率和速率限制,但您可以支付无限制访问权限.
尝试此链接以查看输出的示例(这是在json中,输出也在XML中可用)
https://maps.googleapis.com/maps/api/geocode/json?latlng=40.714224,-73.961452&sensor=true
Far*_*eed 40
你需要 geopy
pip install geopy
然后:
from geopy.geocoders import Nominatim
geolocator = Nominatim()
location = geolocator.reverse("48.8588443, 2.2943506")
print(location.address)
获取更多信息:
print (location.raw)
{'place_id': '24066644', 'osm_id': '2387784956', 'lat': '41.442115', 'lon': '-8.2939909', 'boundingbox': ['41.442015', '41.442215', '-8.2940909', '-8.2938909'], 'address': {'country': 'Portugal', 'suburb': 'Oliveira do Castelo', 'house_number': '99', 'city_district': 'Oliveira do Castelo', 'country_code': 'pt', 'city': 'Oliveira, São Paio e São Sebastião', 'state': 'Norte', 'state_district': 'Ave', 'pedestrian': 'Rua Doutor Avelino Germano', 'postcode': '4800-443', 'county': 'Guimarães'}, 'osm_type': 'node', 'display_name': '99, Rua Doutor Avelino Germano, Oliveira do Castelo, Oliveira, São Paio e São Sebastião, Guimarães, Braga, Ave, Norte, 4800-443, Portugal', 'licence': 'Data © OpenStreetMap contributors, ODbL 1.0. http://www.openstreetmap.org/copyright'}
tur*_*gos 22
我正在寻找类似的功能,我在早先的回复中看到了数据" http://download.geonames.org/export/dump/ "(感谢分享,这是一个很好的来源),并实现了一个基于服务的在cities1000.txt数据上.
你可以看到它在运行 
http://scatter-otl.rhcloud.com/location?lat=36&long=-78.9 (断开链接) 
只需更改您所在位置的纬度和经度即可.
它部署在OpenShift(RedHat平台)上.长时间闲置后的第一次通话可能需要一段时间,但通常表现令人满意.随意使用此服务...
此外,您可以在https://github.com/turgos/Location找到项目源 .
我使用了Geocoder,一个支持多个提供商的优秀Python库,包括Google,Geonames和OpenStreetMaps,仅举几例.我尝试过使用GeoPy库,它经常会超时.为GeoNames开发自己的代码不是最好的利用时间,最终可能会得到不稳定的代码.根据我的经验,Geocoder非常易于使用,并且具有足够好的文档.以下是按纬度和经度查找城市或按城市名称查找纬度/经度的示例代码.
import geocoder
g = geocoder.osm([53.5343609, -113.5065084], method='reverse')
print g.json['city'] # Prints Edmonton
g = geocoder.osm('Edmonton, Canada')
print g.json['lat'], g.json['lng'] # Prints 53.5343609, -113.5065084
我花了大约30分钟试图找到一个如何在Javascript中执行此操作的代码示例.我找不到你发布的问题的快速明确答案.所以...我自己创造了.希望人们可以使用它,而无需深入研究API或盯着他们不知道如何阅读的代码.哈,如果没有别的我可以参考这篇文章为我自己的东西..好问题,并感谢讨论论坛!
这是利用Google API.
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script type="text/javascript" src="http://maps.googleapis.com/maps/api/js?key=<YOURGOOGLEKEY>&sensor=false&v=3&libraries=geometry"></script>
.
//CHECK IF BROWSER HAS HTML5 GEO LOCATION
if (navigator.geolocation) {
    navigator.geolocation.getCurrentPosition(function (position) {
        //GET USER CURRENT LOCATION
        var locCurrent = new google.maps.LatLng(position.coords.latitude, position.coords.longitude);
        //CHECK IF THE USERS GEOLOCATION IS IN AUSTRALIA
        var geocoder = new google.maps.Geocoder();
            geocoder.geocode({ 'latLng': locCurrent }, function (results, status) {
                var locItemCount = results.length;
                var locCountryNameCount = locItemCount - 1;
                var locCountryName = results[locCountryNameCount].formatted_address;
                if (locCountryName == "Australia") {
                    //SET COOKIE FOR GIVING
                    jQuery.cookie('locCountry', locCountryName, { expires: 30, path: '/' }); 
                }
        });
    }
}
| 归档时间: | 
 | 
| 查看次数: | 188109 次 | 
| 最近记录: |