利用高德地图API获取任意两座城市之间的距离!异地也有惊喜!

本文介绍如何使用Python爬虫结合高德地图API,自动化获取大量城市之间的距离信息,以解决统计员工出差飞行距离的问题。通过这种方法,可以避免手动查询的繁琐,将结果直接导出为CSV文件。
摘要由CSDN通过智能技术生成

工作中有时会遇到这样一种场景:年末需要统计所有员工该年的航旅出差情况,然后根据他们的飞行距离补贴一定的交通费。例如如下所示情况:

然而,如果我们使用地图APP等工具逐一进行手工查询,在一家规模稍大的公司,成百上千条数据便很容易让人崩溃。

此时,便需要一种能够批量获取多座城市的位置信息以及他们之间的距离信息的方法。

这里分享一种利用Python爬虫和高德地图API批量获取信息并自动导出到CSV格式文件的做法:

代码原文如下:

import requests
from geopy.distance import geodesic
import csv

'''
例如,我希望获得北京、上海、广州、深圳这四座城市,
任意两座城市之间的距离,以及他们相应的经纬度。只要
把这四座城市的名称放到loc这个列表变量里就可以。如
果要获得其他城市之间的距离,修改loc即可。
'''

loc = ["北京","上海","广州","深圳"]

# 利用高德地图API需要提供key,可以在官网上申请
key = '2ff259313e2a44392d570d5534358105'

# 获取某地的经纬度
def getCoordinate(city):
    url= 'https://restapi.amap.com/v3/geocode/geo?parameters?key='+str(city)+'&address='+str(city)+'&
高德地图 API 中,获取两点之间的直线距离可以通过 `AMap.Geolocation` 和 `AMap.Polyline` 组件结合来实现。以下是一个简单的步骤: 1. **引入依赖库**:首先确保已导入高德地图相关的 JavaScript 库和模块。 ```javascript import AMap from 'amap-js-sdk'; ``` 2. **初始化地图实例**:在需要的地方创建地图实例。 ```javascript const map = new AMap.Map('container', { zoom: 10, // 地图初始缩放级别 center: [116.39, 39.9], // 北京的中心坐标 }); ``` 3. **获取地理编码服务**:用于将地址转换为经纬度。 ```javascript const geocoder = new AMap.Geocoder(); ``` 4. **查询起点和终点的经纬度**:根据实际需求,用户输入或从数据库获取地址,调用 `geocode()` 方法。 ```javascript function getDistance(startAddress, endAddress) { return new Promise((resolve, reject) => { geocoder.getAddress(startAddress, (status, result) => { if (status === 'complete' && result.info === 'OK') { const startPoint = result.formatted_addresses; geocoder.getAddress(endAddress, (status, result) => { if (status === 'complete' && result.info === 'OK') { const endPoint = result.formatted_addresses; // 获取经纬度数组 const startCoord = result.poi ? result.poi.location : result.addressComponent.lnglat; const endCoord = result.poi ? result.poi.location : result.addressComponent.lnglat; // 计算距离 calculateLineDistance(startCoord, endCoord).then(distance => { resolve(distance); }); } else { reject(result.message); } }); } else { reject(result.message); } }); }); } // 自定义方法计算两点间的直线距离 function calculateLineDistance(startCoord, endCoord) { const startLat = startCoord.lat, startLng = startCoord.lng, endLat = endCoord.lat, endLng = endCoord.lng; const distanceService = new AMap.DistanceMatrix(); distanceService.calculate([ { location: startLat + ',' + startLng }, { location: endLat + ',' + endLng } ]).then(response => { const result = response.result; return result.distance.toFixed(2); // 返回千米为单位的距离 }).catch(err => console.error(err)); } ``` 5. **调用距离计算**:当你需要知道两点之间距离时,传入地址并处理返回结果。 ```javascript getDistance('起点地址', '终点地址') .then(distance => { console.log(`两点之间的直线距离是 ${distance} 千米`); }) .catch(error => { console.error('获取距离失败:', error); }); ``` 注意:此代码示例假设你已经在 HTML 文件中添加了名为 "container" 的 div 元素供地图渲染,并且已经设置了 API 密钥。此外,实际项目中可能还需要考虑网络请求的错误处理和性能优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值