1

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

8 个地点的列表会定期更改,因此手动完成任务是不切实际的。我尝试过使用 Google Maps API,但到目前为止还没有成功。理想的解决方案是在 PHP 中,并会生成一个以国家代码为索引、最近的国家(来自 8 个列表)作为值的数组。任何帮助表示赞赏!

4

1 回答 1

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

对于您的用例,您可以使用国家/地区的首都。对于大国,您可能应该在边界附近添加更多国家。

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

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

如果效率是一个问题,我建议建立一个图表,其中每个国家都被存储并与其边境国家联系起来。如果您只查看边境国家,这将大大减少计算工作量。

于 2013-06-14T11:21:56.097 回答