我正在尝试使用在线发现的这个功能来计算地球上两个纬度和经度点之间的距离。
但是,我不知道如何传递我的纬度和经度值,因为我替换了lat1
,lon1
和lat2
,lon2
,我收到错误每一次。
我在哪里输入我想要的纬度和经度值?
import math
def distance(origin, destination):
lat1, lon1 = origin
lat2, lon2 = destination
radius = 6371 # km
dlat = math.radians(lat2-lat1)
dlon = math.radians(lon2-lon1)
a = math.sin(dlat/2) * math.sin(dlat/2) + math.cos(math.radians(lat1)) \
* math.cos(math.radians(lat2)) * math.sin(dlon/2) * math.sin(dlon/2)
c = 2 * math.atan2(math.sqrt(a), math.sqrt(1-a))
d = radius * c
return d
编辑: 例如,如果我有
lat1 = 20 and lon1 = 100
lat2 = 30 and lon2 = 110
为什么当我用函数中的数字替换lon1时它会失败?
答案 0 :(得分:3)
像这样使用:
distance((lat1, lon1), (lat2, lon2))
请注意,函数接收两个两元素元组作为参数(或两个双元素列表,它们是相同的),每个元素代表一个(纬度,经度)对。等价地:
origin = (lat1, lon1)
destination = (lat2, lon2)
distance(origin, destination)
答案 1 :(得分:0)
您可以通过传递每个元组的元组来调用它,例如:
distance(origin=origin_tuple, destination=dest_tuple)
其中
origin_tuple = (origin_lat , origin_long)
dest_tuple = (dest_lat , dest_long)