佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > Python利用百度地圖獲取兩地距離(附demo)

Python利用百度地圖獲取兩地距離(附demo)

熱門標簽:網(wǎng)站文章發(fā)布 銀行業(yè)務 呼叫中心市場需求 智能手機 服務器配置 檢查注冊表項 美圖手機 鐵路電話系統(tǒng)

百度地圖開放平臺

進入百度地圖開放平臺后,登陸用戶,點擊上方的控制臺,按照提示進行激活后創(chuàng)建服務端類型的應用,應用名任意設置,其中白名單校驗不做任何限制可以填寫0.0.0.0/0。創(chuàng)建成功后畫面應如下圖所示,其中訪問應用AK)即途中紅色方框圈起來的部分一定要注意不要隨意泄漏,后面需要使用到,這是后面訪問需要用到的一串口令。

介紹需要用到的API

本項目中所有使用的API均為Web服務API,官方開發(fā)文檔。

1.地點檢索服務

地點檢索服務(又名Place API)是一類Web API接口服務;
服務提供多種場景的地點(POI)檢索功能,包括城市檢索、圓形區(qū)域檢索、矩形區(qū)域檢索。開發(fā)者可通過接口獲取地點(POI)基礎或詳細地理信息。

我們利用這個API來獲取指定地點的經(jīng)緯度(lat, lng)兩個參數(shù)。

2.批量算路服務

批量算路服務(又名RouteMatrix API)是一套以HTTP/HTTPS形式提供的輕量級批量算路接口,用戶可通過該服務,根據(jù)起點和終點坐標計算路線規(guī)劃距離和行駛時間,RouteMatrix API V2.0支持中國大陸地區(qū)。

我們利用這個API來獲取兩個地點(用經(jīng)緯度來給出)之間的路線規(guī)劃距離。

編寫Python程序

0.需要用到的模塊

  •  requests
  • json

1.獲取對應地點的經(jīng)緯度

將傳入的address通過地點檢索服務得到其經(jīng)緯度,返回值為經(jīng)緯度對應的字符串值,中間以逗號隔開,之后跟一個查詢返回狀態(tài),如果查詢失敗,狀態(tài)值不為0。

注意將代碼中的AK換成一開始截圖中的AK碼。

def getPosition(address):
    url = r"http://api.map.baidu.com/place/v2/search?query={}region=全國output=jsonak={}".format(
        address,
        AK  # 這里是一開始截圖用紅色圈起來的部分
    )
    res = requests.get(url)
    json_data = json.loads(res.text)

    if json_data['status'] == 0:
        lat = json_data["results"][0]["location"]["lat"]  # 緯度
        lng = json_data["results"][0]["location"]["lng"]  # 經(jīng)度
    else:
        print("[ERROR] Can not find {}.".format(address))
        return "0,0", json_data["status"]
    return str(lat) + "," + str(lng), json_data["status"]

2.獲取兩地之間的距離

將傳入的兩個地點(以經(jīng)緯度描述)通過批量算路服務得到之間的路線規(guī)劃距離。本范例是以駕車行駛(對應參數(shù)為'driving')的方式來進行計算的。

同樣注意將代碼中的AK換成一開始截圖中的AK碼。

def getDistance(start, end):
    url = "http://api.map.baidu.com/routematrix/v2/driving?output=jsonorigins={}destinations={}ak={}".format(
        start,
        end,
        AK  # 這里是一開始截圖用紅色圈起來的部分
    )
    res = requests.get(url)
    content = res.content
    jsonv = json.loads(str(content, "utf-8"))
    dist = jsonv["result"][0]["distance"]["value"]
    return dist

3.合并函數(shù)調(diào)用

傳入兩個地點名,返回兩地點距離,當某個地點查詢不到時,返回結果設置為-1。

def calcDistance(startName, endName):
    start, status1 = getPosition(startName)
    end, status2 = getPosition(endName)
    if status1 == 0 and status2 == 0:
        return getDistance(start, end)
    else:
        return -1

4.進行簡單的功能測試

運行代碼輸出北京成都之間的距離,其單位為米。

5.對Excel中的批量地點計算距離

data.xlsx文件中的地點全部讀取并計算出距離,將結果保存到本地的result.xlsx文件中,其中我們將距離的單位設置為千米。主模塊代碼如下:

if __name__ == "__main__":
    data = pd.read_excel("data.xlsx")
    res = []
    for i in range(0, len(data)):
        startName = data.iloc[i, 0]
        endName = data.iloc[i, 1]
        dist = calcDistance(startName, endName)
        res.append([startName, endName, dist / 1000])
    pd.DataFrame(res).to_excel(
        "result.xlsx",
        header=["起點", "終點", "距離"],
        index=None,
        encoding="utf-8"
    )

其中data.xlsx文件的內(nèi)容為:


對應的輸出result.xlsx文件內(nèi)容如下:

附錄

# 本次整體的源代碼
AK = "修改為你自己的AK碼即可使用"

import pandas as pd
import requests
import json


def getPosition(address):
    url = r"http://api.map.baidu.com/place/v2/search?query={}region=全國output=jsonak={}".format(
        address,
        AK  # 這里是一開始截圖用紅色圈起來的部分
    )
    res = requests.get(url)
    json_data = json.loads(res.text)

    if json_data['status'] == 0:
        lat = json_data["results"][0]["location"]["lat"]  # 緯度
        lng = json_data["results"][0]["location"]["lng"]  # 經(jīng)度
    else:
        print("[ERROR] Can not find {}.".format(address))
        return "0,0", json_data["status"]
    return str(lat) + "," + str(lng), json_data["status"]


def getDistance(start, end):
    url = "http://api.map.baidu.com/routematrix/v2/driving?output=jsonorigins={}destinations={}ak={}".format(
        start,
        end,
        AK  # 這里是一開始截圖用紅色圈起來的部分
    )
    res = requests.get(url)
    content = res.content
    jsonv = json.loads(str(content, "utf-8"))
    dist = jsonv["result"][0]["distance"]["value"]
    return dist


def calcDistance(startName, endName):
    start, status1 = getPosition(startName)
    end, status2 = getPosition(endName)
    if status1 == 0 and status2 == 0:
        return getDistance(start, end)
    else:
        return -1


if __name__ == "__main__":
    data = pd.read_excel("data.xlsx")
    res = []
    for i in range(0, len(data)):
        startName = data.iloc[i, 0]
        endName = data.iloc[i, 1]
        dist = calcDistance(startName, endName)
        res.append([startName, endName, dist / 1000])
    pd.DataFrame(res).to_excel(
        "result.xlsx",
        header=["起點", "終點", "距離"],
        index=None,
        encoding="utf-8"
    )

到此這篇關于Python利用百度地圖獲取兩地距離的文章就介紹到這了,更多相關Python 百度地圖獲取兩地距離 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 詳解用Python調(diào)用百度地圖正/逆地理編碼API
  • python 爬蟲百度地圖的信息界面的實現(xiàn)方法
  • 利用python和百度地圖API實現(xiàn)數(shù)據(jù)地圖標注的方法
  • python調(diào)用百度地圖WEB服務API獲取地點對應坐標值
  • python通過百度地圖API獲取某地址的經(jīng)緯度詳解
  • Python爬蟲實例_利用百度地圖API批量獲取城市所有的POI點

標簽:長治 紅河 新疆 河南 沈陽 上海 樂山 滄州

巨人網(wǎng)絡通訊聲明:本文標題《Python利用百度地圖獲取兩地距離(附demo)》,本文關鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    尼玛县| 娱乐| 石城县| 固原市| 元朗区| 宾川县| 麻栗坡县| 浪卡子县| 甘孜县| 辉南县| 吉木萨尔县| 隆尧县| 涟源市| 和顺县| 浦县| 潞西市| 廉江市| 乌拉特后旗| 保靖县| 常德市| 射洪县| 宝鸡市| 赞皇县| 南乐县| 枣阳市| 沂水县| 怀集县| 福鼎市| 台中市| 南江县| 金乡县| 白山市| 新巴尔虎右旗| 海门市| 乐都县| 云梦县| 马山县| 内江市| 喀喇| 刚察县| 新宾|