我有一份ISO 3166国家代码清单(240)和8个国家/地区/地区(澳大利亚,丹麦,荷兰,卡塔尔,南非,阿联酋,英国和美国)的清单。我想查看国家代码列表,并为每个代码列出8个列表中最接近的代码。指标(地理距离,直线距离,行驶时间等)不是特别重要,因为它不需要完美,只是合理。
8个位置的列表会定期更改,因此手动执行任务是不切实际的。我尝试过使用谷歌地图API,但到目前为止还没有成功。理想的解决方案是在PHP中,并将导致一个数组,其中国家/地区代码作为索引,最接近的国家/地区(从8的列表中)作为值。任何帮助表示赞赏!
答案 0 :(得分:1)
geonames项目包含您可以使用的公共数据
现在你可以获得地理协同作用之间的距离。
function distance($lat1, $lng1, $lat2, $lng2, $miles = true)
{
$pi80 = M_PI / 180;
$lat1 *= $pi80;
$lng1 *= $pi80;
$lat2 *= $pi80;
$lng2 *= $pi80;
$r = 6372.797; // mean radius of Earth in km
$dlat = $lat2 - $lat1;
$dlng = $lng2 - $lng1;
$a = sin($dlat / 2) * sin($dlat / 2) + cos($lat1) * cos($lat2) * sin($dlng / 2) * sin($dlng / 2);
$c = 2 * atan2(sqrt($a), sqrt(1 - $a));
$km = $r * $c;
return ($miles ? ($km * 0.621371192) : $km);
}
对于您的用例,您可以使用国家/地区的资本。对于大国而言,您应该在寄宿生附近添加更多国家。
这是一个解决方案。您还可以在数据库中存储与国家/地区近似的几何形状并进行精确查询...
然而,起点是数据。你真的想要什么?你有什么数据?
如果效率问题,我建议建立一个图表,其中每个国家都存储并与其边境国家相关联。如果你只看边境国家,这会大大减少计算工作量。