0


Python应用指南:利用高德地图API实现路径规划

高德路径规划API是一套基于HTTP协议的接口服务,旨在为开发者提供便捷的路径规划解决方案。该API支持多种出行方式,包括步行、公交和驾车,能够满足不同场景下的路径查询需求。通过调用这些API,用户可以获得从起点到终点的最优路径建议,以及详细的行驶距离和预计时间等信息。API返回的数据格式灵活,支持JSON和XML两种格式,便于开发者根据自身应用的需求进行解析和处理。

本篇文章就来实现对高德路径API的调用,并展示如何处理返回的数据,最终实现路径规划结果的可视化呈现。

先讲一下方法思路,一共三个步骤;

方法思路

  1. 确认不同路径规划 API URL数据结构,并根据配置参数构建请求URL
  2. 坐标转换——高德坐标系(GCJ-02) to WGS84
  3. 输出shp图层和csv结果

我们先看步行的路径规划的请求API:路径规划-基础 API 文档-开发指南-Web服务 API|高德地图API

https://restapi.amap.com/v3/direction/walking?origin=116.434307,39.90909&destination=116.434446,39.90816&key=<用户的key>

参考服务示例,我们需要输入并配置的参数包括key,orign(起点坐标)、desination(终点坐标)、output 选json、origin_id (起点 POI ID)与destination_id (目的地 POI ID)填不填都可以,有需求的可以填一下,可以提高路径规划的精度。

  1. parameters = {
  2. 'key': api_key,
  3. 'origin': from_location,
  4. 'destination': to_location,
  5. 'output': 'json'
  6. }

首先通过高德API拾取坐标器拾取需要研究的路径的起末点坐标:坐标拾取器 | 高德地图API,这里挑了两个起末点坐标作为示例;

('121.430041,31.154579', '121.318910,31.193987'), # 上海南站 -> 虹桥火车站
('121.492466,31.225879', '121.508419,31.084134'), # 人民广场 -> 复旦大学

步行路径规划

步行路径规划 API 可以规划100km 以内的步行通勤方案,并且返回通勤方案的数据。最大支持 100km 的步行路线规划;

完整代码#运行环境Python 3.11

  1. # -*- coding: utf-8 -*-
  2. import requests
  3. import json
  4. import geopandas as gpd
  5. import pandas as pd
  6. from shapely.geometry import LineString, Point
  7. import glob
  8. import math
  9. # 高德GCJ02(火星坐标系)转GPS84
  10. x_pi = 3.14159265358979324 * 3000.0 / 180.0
  11. pi = 3.1415926535897932384626 # π
  12. a = 6378245.0 # 长半轴
  13. ee = 0.00669342162296594323 # 扁率
  14. def gcj02towgs84(lng, lat):
  15. """
  16. GCJ02(火星坐标系)转GPS84
  17. :param lng:火星坐标系的经度
  18. :param lat:火星坐标系纬度
  19. :return:
  20. """
  21. if out_of_china(lng, lat):
  22. return lng, lat
  23. dlat = transformlat(lng - 105.0, lat - 35.0)
  24. dlng = transformlng(lng - 105.0, lat - 35.0)
  25. radlat = lat / 180.0 * pi
  26. magic = math.sin(radlat)
  27. magic = 1 - ee * magic * magic
  28. sqrtmagic = math.sqrt(magic)
  29. dlat = (dlat * 180.0) / ((a * (1 - ee)) / (magic * sqrtmagic) * pi)
  30. dlng = (dlng * 180.0) / (a / sqrtmagic * math.cos(radlat) * pi)
  31. mglat = lat + dlat
  32. mglng = lng + dlng
  33. return [lng * 2 - mglng, lat * 2 - mglat]
  34. def transformlat(lng, lat):
  35. ret = -100.0 + 2.0 * lng + 3.0 * lat + 0.2 * lat * lat + 0.1 * lng * lat + 0.2 * math.sqrt(math.fabs(lng))
  36. ret += (20.0 * math.sin(6.0 * lng * pi) + 20.0 * math.sin(2.0 * lng * pi)) * 2.0 / 3.0
  37. ret += (20.0 * math.sin(lat * pi) + 40.0 * math.sin(lat / 3.0 * pi)) * 2.0 / 3.0
  38. ret += (160.0 * math.sin(lat / 12.0 * pi) + 320 * math.sin(lat * pi / 30.0)) * 2.0 / 3.0
  39. return ret
  40. def transformlng(lng, lat):
  41. ret = 300.0 + lng + 2.0 * lat + 0.1 * lng * lng + 0.1 * lng * lat + 0.1 * math.sqrt(math.fabs(lng))
  42. ret += (20.0 * math.sin(6.0 * lng * pi) + 20.0 * math.sin(2.0 * lng * pi)) * 2.0 / 3.0
  43. ret += (20.0 * math.sin(lng * pi) + 40.0 * math.sin(lng / 3.0 * pi)) * 2.0 / 3.0
  44. ret += (150.0 * math.sin(lng / 12.0 * pi) + 300.0 * math.sin(lng / 30.0 * pi)) * 2.0 / 3.0
  45. return ret
  46. def out_of_china(lng, lat):
  47. """
  48. 判断是否在国内,不在国内不做偏移
  49. :param lng:
  50. :param lat:
  51. :return:
  52. """
  53. if lng < 72.004 or lng > 137.8347:
  54. return True
  55. if lat < 0.8293 or lat > 55.8271:
  56. return True
  57. return False
  58. def coordinates(c):
  59. lng, lat = c.split(',')
  60. lng, lat = float(lng), float(lat)
  61. wlng, wlat = gcj02towgs84(lng, lat)
  62. return wlng, wlat
  63. def route_planning(api_key, routes):
  64. all_gdfs = []
  65. all_dfs = []
  66. for i, (from_location, to_location) in enumerate(routes):
  67. url = 'https://restapi.amap.com/v3/direction/walking'
  68. parameters = {
  69. 'key': api_key,
  70. 'origin': from_location,
  71. 'destination': to_location,
  72. 'output': 'json'
  73. }
  74. response = requests.get(url, params=parameters)
  75. data = json.loads(response.text)
  76. if data['status'] == '1':
  77. route = data['route']
  78. paths = route['paths']
  79. if paths:
  80. path = paths[0]
  81. distance = path['distance']
  82. duration = path['duration']
  83. steps = path['steps']
  84. print(f"步行路线规划 {i+1}:")
  85. all_coordinates = []
  86. step_data = []
  87. for step in steps:
  88. instruction = step['instruction']
  89. distance = step['distance']
  90. duration = step['duration']
  91. polyline = step['polyline']
  92. print(f"指令: {instruction}, 距离: {distance}米, 时间: {duration}秒, 路径: {polyline}")
  93. # 转换坐标
  94. coordinates_list = [coordinates(c) for c in polyline.split(';')]
  95. all_coordinates.extend(coordinates_list)
  96. # 将数据添加到列表
  97. step_data.append({
  98. '指令': instruction,
  99. '距离': distance,
  100. '时间': duration,
  101. '路径': polyline
  102. })
  103. # 创建LineString
  104. geometry = LineString(all_coordinates)
  105. # 创建GeoDataFrame
  106. gdf = gpd.GeoDataFrame(index=[i], geometry=[geometry])
  107. gdf['distance'] = distance
  108. gdf['duration'] = duration
  109. gdf['route_id'] = i # 添加一个标识符来区分不同的路线
  110. # 保存为SHP文件
  111. gdf.to_file(f'route_{i}.shp', driver='ESRI Shapefile')
  112. # 保存为CSV文件
  113. df = pd.DataFrame(step_data)
  114. df['route_id'] = i # 添加一个标识符来区分不同的路线
  115. df['label'] = f'步行路线规划{i+1}' # 添加标签
  116. df.to_csv(f'route_{i}.csv', index=False, encoding='utf-8-sig')
  117. all_gdfs.append(gdf)
  118. all_dfs.append(df)
  119. print(f"路径 {i+1} 已保存为 route_{i}.shp 和 route_{i}.csv")
  120. else:
  121. print(f"未找到路径 {i+1}")
  122. else:
  123. print(f"路线规划失败 {i+1}: {data['info']}")
  124. # 合并所有GeoDataFrame
  125. combined_gdf = gpd.GeoDataFrame(pd.concat(all_gdfs, ignore_index=True))
  126. combined_gdf.to_file('combined_routes.shp', driver='ESRI Shapefile')
  127. # 合并所有DataFrame
  128. combined_df = pd.concat(all_dfs, ignore_index=True)
  129. combined_df.to_csv('combined_routes.csv', index=False, encoding='utf-8-sig')
  130. print("所有路径已合并并保存为 combined_routes.shp 和 combined_routes.csv")
  131. if __name__ == '__main__':
  132. api_key = '你的key' # 替换为你的高德地图API密钥
  133. # 定义多个起终点对
  134. routes = [
  135. ('121.430041,31.154579', '121.318910,31.193987'), # 上海南站 -> 虹桥火车站
  136. ('121.492466,31.225879', '121.508419,31.084134'), # 人民广场 -> 复旦大学
  137. # 可以继续添加更多的起终点对
  138. ]
  139. route_planning(api_key, routes)

结果会输出每个路径的单独shp和csv,和合并后的结果为 combined_routes.shp 和 combined_outes.csv;

在调用高德路径规划API并获取到步行路径的详细数据后,我们可以将这些数据在地图上进行可视化,看到步行的具体路径;

同样的,驾车路径规划参考服务示例,我们需要输入并配置的参数包括key、orign(起点坐标)、desination(终点坐标)、output 选json,其他的例如waypoints(途径点)、province(车牌)、strategy(驾车选择策略,驾车策略有20种,详见文档,本脚本选择是''11'')等一些参数,可以参考高德的API文档进行配置,这里不再赘述;

驾车路径规划

驾车路径规划 API 可以规划以小客车、轿车通勤出行的方案,并且返回通勤方案的数据。

完整代码#运行环境Python 3.11

  1. # -*- coding: utf-8 -*-
  2. import requests
  3. import json
  4. import geopandas as gpd
  5. import pandas as pd
  6. from shapely.geometry import LineString, Point
  7. import math
  8. # 高德GCJ02(火星坐标系)转GPS84
  9. x_pi = 3.14159265358979324 * 3000.0 / 180.0
  10. pi = 3.1415926535897932384626 # π
  11. a = 6378245.0 # 长半轴
  12. ee = 0.00669342162296594323 # 扁率
  13. def gcj02towgs84(lng, lat):
  14. """
  15. GCJ02(火星坐标系)转GPS84
  16. :param lng:火星坐标系的经度
  17. :param lat:火星坐标系纬度
  18. :return:
  19. """
  20. if out_of_china(lng, lat):
  21. return lng, lat
  22. dlat = transformlat(lng - 105.0, lat - 35.0)
  23. dlng = transformlng(lng - 105.0, lat - 35.0)
  24. radlat = lat / 180.0 * pi
  25. magic = math.sin(radlat)
  26. magic = 1 - ee * magic * magic
  27. sqrtmagic = math.sqrt(magic)
  28. dlat = (dlat * 180.0) / ((a * (1 - ee)) / (magic * sqrtmagic) * pi)
  29. dlng = (dlng * 180.0) / (a / sqrtmagic * math.cos(radlat) * pi)
  30. mglat = lat + dlat
  31. mglng = lng + dlng
  32. return [lng * 2 - mglng, lat * 2 - mglat]
  33. def transformlat(lng, lat):
  34. ret = -100.0 + 2.0 * lng + 3.0 * lat + 0.2 * lat * lat + 0.1 * lng * lat + 0.2 * math.sqrt(math.fabs(lng))
  35. ret += (20.0 * math.sin(6.0 * lng * pi) + 20.0 * math.sin(2.0 * lng * pi)) * 2.0 / 3.0
  36. ret += (20.0 * math.sin(lat * pi) + 40.0 * math.sin(lat / 3.0 * pi)) * 2.0 / 3.0
  37. ret += (160.0 * math.sin(lat / 12.0 * pi) + 320 * math.sin(lat * pi / 30.0)) * 2.0 / 3.0
  38. return ret
  39. def transformlng(lng, lat):
  40. ret = 300.0 + lng + 2.0 * lat + 0.1 * lng * lng + 0.1 * lng * lat + 0.1 * math.sqrt(math.fabs(lng))
  41. ret += (20.0 * math.sin(6.0 * lng * pi) + 20.0 * math.sin(2.0 * lng * pi)) * 2.0 / 3.0
  42. ret += (20.0 * math.sin(lng * pi) + 40.0 * math.sin(lng / 3.0 * pi)) * 2.0 / 3.0
  43. ret += (150.0 * math.sin(lng / 12.0 * pi) + 300.0 * math.sin(lng / 30.0 * pi)) * 2.0 / 3.0
  44. return ret
  45. def out_of_china(lng, lat):
  46. """
  47. 判断是否在国内,不在国内不做偏移
  48. :param lng:
  49. :param lat:
  50. :return:
  51. """
  52. if lng < 72.004 or lng > 137.8347:
  53. return True
  54. if lat < 0.8293 or lat > 55.8271:
  55. return True
  56. return False
  57. def coordinates(c):
  58. lng, lat = c.split(',')
  59. lng, lat = float(lng), float(lat)
  60. wlng, wlat = gcj02towgs84(lng, lat)
  61. return wlng, wlat
  62. def driving_planning(api_key, routes):
  63. all_gdfs = []
  64. all_dfs = []
  65. for i, (from_location, to_location) in enumerate(routes):
  66. url = 'https://restapi.amap.com/v3/direction/driving'
  67. parameters = {
  68. 'key': api_key,
  69. 'origin': from_location,
  70. 'destination': to_location,
  71. 'strategy': '11',
  72. 'output': 'json'
  73. }
  74. response = requests.get(url, params=parameters)
  75. data = json.loads(response.text)
  76. if data['status'] == '1':
  77. route = data['route']
  78. paths = route['paths']
  79. if paths:
  80. path = paths[0]
  81. distance = path['distance']
  82. duration = path['duration']
  83. steps = path['steps']
  84. print(f"驾车路线规划 {i+1}:")
  85. all_coordinates = []
  86. step_data = []
  87. for step in steps:
  88. instruction = step['instruction']
  89. distance = step['distance']
  90. duration = step['duration']
  91. polyline = step['polyline']
  92. print(f"指令: {instruction}, 距离: {distance}米, 时间: {duration}秒, 路径: {polyline}")
  93. # 转换坐标
  94. coordinates_list = [coordinates(c) for c in polyline.split(';')]
  95. all_coordinates.extend(coordinates_list)
  96. # 将数据添加到列表
  97. step_data.append({
  98. '指令': instruction,
  99. '距离': distance,
  100. '时间': duration,
  101. '路径': polyline
  102. })
  103. # 创建LineString
  104. geometry = LineString(all_coordinates)
  105. # 创建GeoDataFrame
  106. gdf = gpd.GeoDataFrame(index=[i], geometry=[geometry])
  107. gdf['distance'] = distance
  108. gdf['duration'] = duration
  109. gdf['route_id'] = i # 添加一个标识符来区分不同的路线
  110. # 保存为SHP文件
  111. gdf.to_file(f'driving_route_{i}.shp', driver='ESRI Shapefile')
  112. # 保存为CSV文件
  113. df = pd.DataFrame(step_data)
  114. df['route_id'] = i # 添加一个标识符来区分不同的路线
  115. df['label'] = f'驾车路线规划{i+1}' # 添加标签
  116. df.to_csv(f'driving_route_{i}.csv', index=False, encoding='utf-8-sig')
  117. all_gdfs.append(gdf)
  118. all_dfs.append(df)
  119. print(f"路径 {i+1} 已保存为 driving_route_{i}.shp 和 driving_route_{i}.csv")
  120. else:
  121. print(f"未找到路径 {i+1}")
  122. else:
  123. print(f"路线规划失败 {i+1}: {data['info']}")
  124. # 合并所有GeoDataFrame
  125. combined_gdf = gpd.GeoDataFrame(pd.concat(all_gdfs, ignore_index=True))
  126. combined_gdf.to_file('combined_driving_routes.shp', driver='ESRI Shapefile')
  127. # 合并所有DataFrame
  128. combined_df = pd.concat(all_dfs, ignore_index=True)
  129. combined_df.to_csv('combined_driving_routes.csv', index=False, encoding='utf-8-sig')
  130. print("所有路径已合并并保存为 combined_driving_routes.shp 和 combined_driving_routes.csv")
  131. if __name__ == '__main__':
  132. api_key = '你的key' # 替换为你的高德地图API密钥
  133. # 定义多个起终点对
  134. routes = [
  135. ('121.596168,31.194734', '121.42837,31.230395'), # 示例起终点
  136. ('121.387047,31.108427', '121.506295,31.281965'), # 示例起终点
  137. # 可以继续添加更多的起终点对
  138. ]
  139. driving_planning(api_key, routes)

同样的 ,结果会输出每个路径的单独shp和csv,和合并后的结果为 combined_driving_routes.shp 和 combined_driving_routes.csv,在调用高德路径规划API并获取到驾车路径的详细数据后,我们可以将这些数据在地图上进行可视化,看到驾车的具体路径;

骑行路径规划参考服务示例,我们需要参数就更少了,只需要输入并配置的参数包括key、orign(起点坐标)、desination(终点坐标)、output 选json即可;

骑行路径规划

骑行路径规划用于规划骑行通勤方案,规划时会考虑天桥、单行线、封路等情况。最大支持 500km 的骑行路线规划。

完整代码#运行环境Python 3.11

  1. # -*- coding: utf-8 -*-
  2. import requests
  3. import json
  4. import geopandas as gpd
  5. import pandas as pd
  6. from shapely.geometry import LineString, Point
  7. import math
  8. # 高德GCJ-02坐标转换为WGS-84坐标
  9. x_pi = 3.14159265358979324 * 3000.0 / 180.0
  10. pi = 3.1415926535897932384626 # π
  11. a = 6378245.0 # 长半轴
  12. ee = 0.00669342162296594323 # 扁率
  13. def gcj02towgs84(lng, lat):
  14. """
  15. 将GCJ-02坐标转换为WGS-84坐标。
  16. :param lng: 火星坐标系的经度
  17. :param lat: 火星坐标系的纬度
  18. :return: WGS-84坐标系的经度和纬度
  19. """
  20. if out_of_china(lng, lat):
  21. return lng, lat
  22. dlat = transformlat(lng - 105.0, lat - 35.0)
  23. dlng = transformlng(lng - 105.0, lat - 35.0)
  24. radlat = lat / 180.0 * pi
  25. magic = math.sin(radlat)
  26. magic = 1 - ee * magic * magic
  27. sqrtmagic = math.sqrt(magic)
  28. dlat = (dlat * 180.0) / ((a * (1 - ee)) / (magic * sqrtmagic) * pi)
  29. dlng = (dlng * 180.0) / (a / sqrtmagic * math.cos(radlat) * pi)
  30. mglat = lat + dlat
  31. mglng = lng + dlng
  32. return [lng * 2 - mglng, lat * 2 - mglat]
  33. def transformlat(lng, lat):
  34. """
  35. 计算坐标偏移量(纬度方向)。
  36. :param lng: 经度
  37. :param lat: 纬度
  38. :return: 纬度偏移量
  39. """
  40. ret = -100.0 + 2.0 * lng + 3.0 * lat + 0.2 * lat * lat + 0.1 * lng * lat + 0.2 * math.sqrt(math.fabs(lng))
  41. ret += (20.0 * math.sin(6.0 * lng * pi) + 20.0 * math.sin(2.0 * lng * pi)) * 2.0 / 3.0
  42. ret += (20.0 * math.sin(lat * pi) + 40.0 * math.sin(lat / 3.0 * pi)) * 2.0 / 3.0
  43. ret += (160.0 * math.sin(lat / 12.0 * pi) + 320 * math.sin(lat * pi / 30.0)) * 2.0 / 3.0
  44. return ret
  45. def transformlng(lng, lat):
  46. """
  47. 计算坐标偏移量(经度方向)。
  48. :param lng: 经度
  49. :param lat: 纬度
  50. :return: 经度偏移量
  51. """
  52. ret = 300.0 + lng + 2.0 * lat + 0.1 * lng * lng + 0.1 * lng * lat + 0.1 * math.sqrt(math.fabs(lng))
  53. ret += (20.0 * math.sin(6.0 * lng * pi) + 20.0 * math.sin(2.0 * lng * pi)) * 2.0 / 3.0
  54. ret += (20.0 * math.sin(lng * pi) + 40.0 * math.sin(lng / 3.0 * pi)) * 2.0 / 3.0
  55. ret += (150.0 * math.sin(lng / 12.0 * pi) + 300.0 * math.sin(lng / 30.0 * pi)) * 2.0 / 3.0
  56. return ret
  57. def out_of_china(lng, lat):
  58. """
  59. 判断坐标是否在中国范围内,不在国内不做偏移。
  60. :param lng: 经度
  61. :param lat: 纬度
  62. :return: 布尔值,是否在中国范围内
  63. """
  64. if lng < 72.004 or lng > 137.8347:
  65. return True
  66. if lat < 0.8293 or lat > 55.8271:
  67. return True
  68. return False
  69. def coordinates(c):
  70. """
  71. 将字符串形式的坐标转换为浮点数,并进行坐标转换。
  72. :param c: 坐标字符串,格式为 "经度,纬度"
  73. :return: 转换后的WGS-84坐标
  74. """
  75. lng, lat = c.split(',')
  76. lng, lat = float(lng), float(lat)
  77. wlng, wlat = gcj02towgs84(lng, lat)
  78. return wlng, wlat
  79. def bicycling_planning(api_key, routes):
  80. """
  81. 实现骑行路径规划,并将结果保存为SHP和CSV文件。
  82. :param api_key: 高德地图API密钥
  83. :param routes: 起终点对列表,每个元素是一个元组 (from_location, to_location)
  84. """
  85. all_gdfs = []
  86. all_dfs = []
  87. for i, (from_location, to_location) in enumerate(routes):
  88. # 构建请求URL和参数
  89. url = 'https://restapi.amap.com/v4/direction/bicycling'
  90. parameters = {
  91. 'key': api_key,
  92. 'origin': from_location,
  93. 'destination': to_location,
  94. 'output': 'json'
  95. }
  96. # 发送请求
  97. response = requests.get(url, params=parameters)
  98. data = json.loads(response.text)
  99. if data['errcode'] == 0:
  100. # 获取路径规划数据
  101. paths = data['data']['paths']
  102. if paths:
  103. path = paths[0]
  104. distance = path['distance']
  105. duration = path['duration']
  106. steps = path['steps']
  107. print(f"骑行路线规划 {i+1}:")
  108. all_coordinates = []
  109. step_data = []
  110. for step in steps:
  111. instruction = step['instruction']
  112. road = step['road']
  113. distance = step['distance']
  114. duration = step['duration']
  115. polyline = step['polyline']
  116. print(f"指令: {instruction}, 道路: {road}, 距离: {distance}米, 时间: {duration}秒, 路径: {polyline}")
  117. # 转换坐标
  118. coordinates_list = [coordinates(c) for c in polyline.split(';')]
  119. all_coordinates.extend(coordinates_list)
  120. # 将数据添加到列表
  121. step_data.append({
  122. '指令': instruction,
  123. '道路': road,
  124. '距离': distance,
  125. '时间': duration,
  126. '路径': polyline
  127. })
  128. # 创建LineString
  129. geometry = LineString(all_coordinates)
  130. # 创建GeoDataFrame
  131. gdf = gpd.GeoDataFrame(index=[i], geometry=[geometry])
  132. gdf['distance'] = distance
  133. gdf['duration'] = duration
  134. gdf['route_id'] = i # 添加一个标识符来区分不同的路线
  135. # 保存为SHP文件
  136. gdf.to_file(f'bicycling_route_{i}.shp', driver='ESRI Shapefile')
  137. # 保存为CSV文件
  138. df = pd.DataFrame(step_data)
  139. df['route_id'] = i # 添加一个标识符来区分不同的路线
  140. df['label'] = f'骑行路线规划{i+1}' # 添加标签
  141. df.to_csv(f'bicycling_route_{i}.csv', index=False, encoding='utf-8-sig')
  142. all_gdfs.append(gdf)
  143. all_dfs.append(df)
  144. print(f"路径 {i+1} 已保存为 bicycling_route_{i}.shp 和 bicycling_route_{i}.csv")
  145. else:
  146. print(f"未找到路径 {i+1}")
  147. else:
  148. print(f"路线规划失败 {i+1}: {data['errmsg']}")
  149. # 合并所有GeoDataFrame
  150. combined_gdf = gpd.GeoDataFrame(pd.concat(all_gdfs, ignore_index=True))
  151. combined_gdf.to_file('combined_bicycling_routes.shp', driver='ESRI Shapefile')
  152. # 合并所有DataFrame
  153. combined_df = pd.concat(all_dfs, ignore_index=True)
  154. combined_df.to_csv('combined_bicycling_routes.csv', index=False, encoding='utf-8-sig')
  155. print("所有路径已合并并保存为 combined_bicycling_routes.shp 和 combined_bicycling_routes.csv")
  156. if __name__ == '__main__':
  157. api_key = '你的key' # 替换为你的高德地图API密钥
  158. # 定义多个起终点对
  159. routes = [
  160. ('121.481453,31.154145', '121.534596,31.233022'), # 示例起终点
  161. ('121.49956,31.240278', '121.569872,31.328836'), # 示例起终点
  162. # 可以继续添加更多的起终点对
  163. ]
  164. # 调用骑行路径规划函数
  165. bicycling_planning(api_key, routes)

同样的 ,结果会输出每个路径的单独shp和csv,和合并后的结果为 combined_bicycling_routes.shp 和 combined_bicycling_routes.csv,在调用高德路径规划API并获取到骑行路径的详细数据后,我们可以将这些数据在地图上进行可视化,看到骑行的具体路径;

文章仅用于分享个人学习成果与个人存档之用,分享知识,如有侵权,请联系作者进行删除。所有信息均基于作者的个人理解和经验,不代表任何官方立场或权威解读。


本文转载自: https://blog.csdn.net/weixin_45812624/article/details/143180592
版权归原作者 图说交通 所有, 如有侵权,请联系我们删除。

“Python应用指南:利用高德地图API实现路径规划”的评论:

还没有评论