如何利用python计算经纬度距离

 1     def geodistance(self, lng1, lat1, lng2, lat2):
 2         # lng1,lat1,lng2,lat2 = (120.12802999999997,30.28708,115.86572000000001,28.7427)
 3         lng1, lat1, lng2, lat2 = map(radians, [float(lng1), float(lat1), float(lng2), float(lat2)])  # 经纬度转换成弧度
 4         dlon = lng2 - lng1
 5         dlat = lat2 - lat1
 6         a = sin(dlat / 2) ** 2 + cos(lat1) * cos(lat2) * sin(dlon / 2) ** 2
 7         distance = 2 * asin(sqrt(a)) * 6371 * 1000  # 地球平均半径,6371km
 8         # 单位:米
 9         distance = round(distance, 3)
10         return distance

 

posted @ 2022-03-02 13:15  自由风~  阅读(751)  评论(0)    收藏  举报