Ily*_*kov 0 python google-maps distance
我使用 gmail 地理编码功能获取经度和纬度。现在我需要计算两点之间的距离。我发现了Haversine 公式并且它运行良好,但是在google js api 中我找到了几何库中的computeDistanceBetween(lat,lng) 方法。我的问题是 python 有函数或库吗?
您可以使用 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)
使用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)
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)
这将返回球体上点之间的角距离。要获得距离长度(公里),请将结果乘以地球半径。
但你也可以在公式集合中查找它,因此会出现一堆反对票;-)
| 归档时间: |
|
| 查看次数: |
10653 次 |
| 最近记录: |