使用python计算谷歌地图中两点之间的距离

Ily*_*kov 0 python google-maps distance

我使用 gmail 地理编码功能获取经度和纬度。现在我需要计算两点之间的距离。我发现了Haversine 公式并且它运行良好,但是在google js api 中我找到了几何库中的computeDistanceBetween(lat,lng) 方法。我的问题是 python 有函数或库吗?

Om *_*ash 6

您可以使用 Google Maps API 计算两点之间的距离。

要查找两个城市之间的距离:

import googlemaps 
# Requires API key 
gmaps = googlemaps.Client(key='Your_API_key')  
# Requires cities name 
distance = gmaps.distance_matrix('Delhi','Mumbai')['rows'][0]['elements'][0]

print(distance)
{u'distance': {u'text': u'1,418 km', u'value': 1417632},
 u'duration': {u'text': u'1 day 0 hours', u'value': 87010},
 u'status': u'OK'}
Run Code Online (Sandbox Code Playgroud)

如果您有出发地和目的地的地理坐标(纬度和经度),请执行以下操作:

# Requires geo-coordinates(latitude/longitude) of origin and destination
origin_latitude = 12.9551779
origin_longitude = 77.6910334
destination_latitude = 28.505278
destination_longitude = 77.327774
distance = gmaps.distance_matrix([str(origin_latitude) + " " + str(origin_longitude)], [str(destination_latitude) + " " + str(destination_longitude)], mode='walking')['rows'][0]['elements'][0]

print(distance)
{u'distance': {u'text': u'2,014 km', u'value': 2013656},
 u'duration': {u'text': u'16 days 23 hours', u'value': 1464529},
 u'status': u'OK'}
Run Code Online (Sandbox Code Playgroud)


Mee*_*eer 6

使用geopy https://pypi.org/project/geopy/

In [39]: from geopy.distance import geodesic

In [40]: you = ("73.6490763,-43.9762069")

In [41]: me = ("73.646628,-43.970497")

In [42]: miles = geodesic(me,you).miles

In [43]: f"Miles: {miles:.2f}"
Out[43]: 'Miles: 0.20'
Run Code Online (Sandbox Code Playgroud)


Alf*_*lfe 5

from math import *

def greatCircleDistance((lat1, lon1), (lat2, lon2)):
  def haversin(x):
    return sin(x/2)**2 
  return 2 * asin(sqrt(
      haversin(lat2-lat1) +
      cos(lat1) * cos(lat2) * haversin(lon2-lon1)))
Run Code Online (Sandbox Code Playgroud)

这将返回球体上点之间的角距离。要获得距离长度(公里),请将结果乘以地球半径。

但你也可以在公式集合中查找它,因此会出现一堆反对票;-)