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)填不填都可以,有需求的可以填一下,可以提高路径规划的精度。

        parameters = {
            'key': api_key,
            'origin': from_location,
            'destination': to_location,
            'output': 'json'
        }

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

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

步行路径规划

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

完整代码#运行环境Python 3.11

# -*- coding: utf-8 -*-
import requests
import json
import geopandas as gpd
import pandas as pd
from shapely.geometry import LineString, Point
import glob
import math

# 高德GCJ02(火星坐标系)转GPS84
x_pi = 3.14159265358979324 * 3000.0 / 180.0
pi = 3.1415926535897932384626  # π
a = 6378245.0  # 长半轴
ee = 0.00669342162296594323  # 扁率

def gcj02towgs84(lng, lat):
    """
    GCJ02(火星坐标系)转GPS84
    :param lng:火星坐标系的经度
    :param lat:火星坐标系纬度
    :return:
    """
    if out_of_china(lng, lat):
        return lng, lat
    dlat = transformlat(lng - 105.0, lat - 35.0)
    dlng = transformlng(lng - 105.0, lat - 35.0)
    radlat = lat / 180.0 * pi
    magic = math.sin(radlat)
    magic = 1 - ee * magic * magic
    sqrtmagic = math.sqrt(magic)
    dlat = (dlat * 180.0) / ((a * (1 - ee)) / (magic * sqrtmagic) * pi)
    dlng = (dlng * 180.0) / (a / sqrtmagic * math.cos(radlat) * pi)
    mglat = lat + dlat
    mglng = lng + dlng
    return [lng * 2 - mglng, lat * 2 - mglat]

def transformlat(lng, lat):
    ret = -100.0 + 2.0 * lng + 3.0 * lat + 0.2 * lat * lat + 0.1 * lng * lat + 0.2 * math.sqrt(math.fabs(lng))
    ret += (20.0 * math.sin(6.0 * lng * pi) + 20.0 * math.sin(2.0 * lng * pi)) * 2.0 / 3.0
    ret += (20.0 * math.sin(lat * pi) + 40.0 * math.sin(lat / 3.0 * pi)) * 2.0 / 3.0
    ret += (160.0 * math.sin(lat / 12.0 * pi) + 320 * math.sin(lat * pi / 30.0)) * 2.0 / 3.0
    return ret

def transformlng(lng, lat):
    ret = 300.0 + lng + 2.0 * lat + 0.1 * lng * lng + 0.1 * lng * lat + 0.1 * math.sqrt(math.fabs(lng))
    ret += (20.0 * math.sin(6.0 * lng * pi) + 20.0 * math.sin(2.0 * lng * pi)) * 2.0 / 3.0
    ret += (20.0 * math.sin(lng * pi) + 40.0 * math.sin(lng / 3.0 * pi)) * 2.0 / 3.0
    ret += (150.0 * math.sin(lng / 12.0 * pi) + 300.0 * math.sin(lng / 30.0 * pi)) * 2.0 / 3.0
    return ret

def out_of_china(lng, lat):
    """
    判断是否在国内,不在国内不做偏移
    :param lng:
    :param lat:
    :return:
    """
    if lng < 72.004 or lng > 137.8347:
        return True
    if lat < 0.8293 or lat > 55.8271:
        return True
    return False

def coordinates(c):
    lng, lat = c.split(',')
    lng, lat = float(lng), float(lat)
    wlng, wlat = gcj02towgs84(lng, lat)
    return wlng, wlat

de
高德地图API提供了多种路径规划服务,包括驾车路径规划、步行路径规划、公交路径规划、骑行路径规划等。其中,驾车路径规划应用最广泛的一种规划方式。下面以驾车路径规划为例,介绍一下如何使用高德地图API进行路径规划。 1. 准备工作 首先,需要在高德开放平台上注册账号,并创建应用。创建应用后,可以获取到一个应用Key,用于调用API。 2. 发送请求 使用高德地图API进行路径规划,需要向以下接口发送请求: ``` https://restapi.amap.com/v3/direction/driving ``` 其中,`direction/driving`表示进行驾车路径规划。 在请求中需要包含以下参数: - `key`:应用Key,用于身份验证。 - `origin`:起点坐标,格式为“经度,纬度”。 - `destination`:终点坐标,格式为“经度,纬度”。 例如,下面是一个请求示例: ``` https://restapi.amap.com/v3/direction/driving?key=yourkey&origin=116.481028,39.989643&destination=116.434446,39.90816 ``` 3. 处理响应 发送请求后,会得到一个JSON格式的响应。响应中包含了路径规划的结果,包括路线、路况、收费等信息。可以根据需要对响应进行解析,提取出需要的信息。 以下是一个响应的示例: ```json { "status": "1", "info": "OK", "infocode": "10000", "count": "1", "route": { "origin": "116.481028,39.989643", "destination": "116.434446,39.90816", "taxi_cost": "34.7", "paths": [ { "distance": "11433", "duration": "2335", "strategy": "速度优先", "tolls": "0", "toll_distance": "0", "steps": [ { "instruction": "从“清华大学(东门)”出发,沿“清华东路”向南行驶40米左右,右转进入“清华东路”。", "orientation": "南", "road": "清华东路", "distance": "101", "duration": "43", "polyline": "116.481846,39.989564;116.481822,39.989425;116.481784,39.989302;116.481724,39.98922;116.481601,39.989177;116.481479,39.989167;116.481357,39.989175;116.481233,39.9892;116.48112,39.989239;116.481014,39.98929;116.48091,39.989355;116.480807,39.989423;116.480703,39.989498;116.480599,39.989576;116.4805,39.989655;116.480396,39.98973;116.480288,39.98979;116.480181,39.989834;116.48007,39.989868", "action": "右转", "assistant_action": "进入", "cities": [], "road_inter": "清华东路", "tmcs": [] }, ... ] } ] } } ``` 以上就是使用高德地图API进行驾车路径规划的基本方法。其他类型的路径规划也可以按照类似的方法进行。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

图说交通

买猫粮,楼下的流浪猫在等我

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值