我有一张地图,上面标记了多个点的纬度和经度,并想要知道它们之间的距离。
因此,给定一组纬度和经度坐标,在Python中如何计算它们之间的距离?
我曾经写过一篇Python版本的这个答案。它详细介绍了使用Haversine公式来计算距离(以千米为单位)的方法。
import math
def get_distance(lat_1, lng_1, lat_2, lng_2):
d_lat = lat_2 - lat_1
d_lng = lng_2 - lng_1
temp = (
math.sin(d_lat / 2) ** 2
+ math.cos(lat_1)
* math.cos(lat_2)
* math.sin(d_lng / 2) ** 2
)
return 6373.0 * (2 * math.atan2(math.sqrt(temp), math.sqrt(1 - temp)))
确保传递给函数的坐标为弧度制。如果它们是以度数表示的,可以先进行转换:
lng_1, lat_1, lng_2, lat_2 = map(math.radians, [lng_1, lat_1, lng_2, lat_2])