我正在使用 SimpleGeo API ,我需要按邮政编码或城市名称获取地点的纬度/经度。我知道有很多关于通过邮政编码获取坐标的问题,并且有许多不错的数据库。但是它们与SimpleGeo的数据密切相关吗?我不希望拥有SimpleGeo数据库中存在的精确城市名称/邮政编码,因为我的数据库与SG的数据库不同而无处可去。
或者,我可以完全移动到 Foursquare API ,如果它提供此类数据,但这不太可取。
所以,我的问题是:
答案 0 :(得分:1)
是的,您可以使用SimpleGeo Context API来执行此操作。 使用城市名称或邮政编码作为地址参数调用SimpleGeo上下文端点,如下所示: http://api.simplegeo.com/1.0/context/address.json?address=98006
响应具有嵌入在返回的JSON blob的“查询”部分中的纬度和经度:
{
“查询”:{
“纬度”:40.745717,
“东经”: - 73.988121
...
},
...
}
希望这有帮助。
谢谢,
-Nikhil
答案 1 :(得分:0)
如果它有帮助...... 以下是如何使用谷歌的地理编码器获取zip码的纬度/经度。假设您有一个带有ID“location”的HTML输入(使用jqueryui自动完成小部件):
// insert a div for autocomplete results
$("#location").after('<div id="location-results"></div>');
$("#location").autocomplete({
appendTo:$("#location-results"),
minLength: 3,
open: acOpen,
select: acSelect,
close: acClose,
source: acSource
});
function acOpen(event, ui){
// no op, but put code here to handle results list open if you need it
}
function acSelect(event, ui){
// fired when user selects a result from the autocomplete list
// assuming you are using the json2.js library for json parsing/decoding
alert(JSON.stringify(ui.item));
// the lat/lng is in ui.item.latLng.lat() and ui.item.latLng.lng()
// ui.item.latLng is of type google.maps.LatLng (see v3 api)
}
function function acClose(event, ui){
// no op, but put code here to handle results list close if you need it
}
function acSource(request, response) {
// implements the autocomplete source for the widget
geocoder.geocode( {'address': request.term }, function(results, status) {
if(undefined!==results){
var postal_code='';
var city = '';
var state = '';
var country = '';
response($.map(results, function(item) {
$.each(item.address_components, function(item_i, item_v){
$.each(item_v.types, function(type_i, type_v){
switch(type_v){
case "locality": case "administrative_area_level_3":
city = item_v.long_name;
break;
case "administrative_area_level_2":
break;
case "street_number":
break;
case "route":
break;
case "administrative_area_level_1":
state = item_v.long_name;
break;
case "country":
country = item_v.long_name;
break;
case "postal_code":
postal_code = item_v.long_name;
break;
}
});
});
// the object that gets returned and is ui.item on select event
return {
label : item.formatted_address,
value : item.formatted_address,
latLng : item.geometry.location,
country : country,
state : state,
city : city,
postal_code : postal_code,
source : "google"
};
}));
}
}
}
}
google的地理编码器可以对邮政编码进行地理编码,没问题。