如何从列表中找到最近的国家/地区

时间:2013-06-14 11:14:22

标签: php api google-maps geolocation geography

我有一份ISO 3166国家代码清单(240)和8个国家/地区/地区(澳大利亚,丹麦,荷兰,卡塔尔,南非,阿联酋,英国和美国)的清单。我想查看国家代码列表,并为每个代码列出8个列表中最接近的代码。指标(地理距离,直线距离,行驶时间等)不是特别重要,因为它不需要完美,只是合理。

8个位置的列表会定期更改,因此手动执行任务是不切实际的。我尝试过使用谷歌地图API,但到目前为止还没有成功。理想的解决方案是在PHP中,并将导致一个数组,其中国家/地区代码作为索引,最接近的国家/地区(从8的列表中)作为值。任何帮助表示赞赏!

1 个答案:

答案 0 :(得分:1)

geonames项目包含您可以使用的公共数据

http://www.geonames.org/

现在你可以获得地理协同作用之间的距离。

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);
}

对于您的用例,您可以使用国家/地区的资本。对于大国而言,您应该在寄宿生附近添加更多国家。

这是一个解决方案。您还可以在数据库中存储与国家/地区近似的几何形状并进行精确查询...

然而,起点是数据。你真的想要什么?你有什么数据?

如果效率问题,我建议建立一个图表,其中每个国家都存储并与其边境国家相关联。如果你只看边境国家,这会大大减少计算工作量。