婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > Python利用百度地圖獲取兩地距離(附demo)

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

熱門標(biāo)簽:銀川電話機(jī)器人電話 預(yù)覽式外呼系統(tǒng) 企業(yè)彩鈴地圖標(biāo)注 上海正規(guī)的外呼系統(tǒng)最新報(bào)價(jià) 電銷機(jī)器人錄音要學(xué)習(xí)什么 長(zhǎng)春極信防封電銷卡批發(fā) 外賣地址有什么地圖標(biāo)注 如何地圖標(biāo)注公司 煙臺(tái)電話外呼營(yíng)銷系統(tǒng)

百度地圖開(kāi)放平臺(tái)

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

介紹需要用到的API

本項(xiàng)目中所有使用的API均為Web服務(wù)API,官方開(kāi)發(fā)文檔。

1.地點(diǎn)檢索服務(wù)

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

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

2.批量算路服務(wù)

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

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

編寫Python程序

0.需要用到的模塊

  •  requests
  • json

1.獲取對(duì)應(yīng)地點(diǎn)的經(jīng)緯度

將傳入的address通過(guò)地點(diǎn)檢索服務(wù)得到其經(jīng)緯度,返回值為經(jīng)緯度對(duì)應(yīng)的字符串值,中間以逗號(hào)隔開(kāi),之后跟一個(gè)查詢返回狀態(tài),如果查詢失敗,狀態(tài)值不為0。

注意將代碼中的AK換成一開(kāi)始截圖中的AK碼。

def getPosition(address):
    url = r"http://api.map.baidu.com/place/v2/search?query={}region=全國(guó)output=jsonak={}".format(
        address,
        AK  # 這里是一開(kāi)始截圖用紅色圈起來(lái)的部分
    )
    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.獲取兩地之間的距離

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

同樣注意將代碼中的AK換成一開(kāi)始截圖中的AK碼。

def getDistance(start, end):
    url = "http://api.map.baidu.com/routematrix/v2/driving?output=jsonorigins={}destinations={}ak={}".format(
        start,
        end,
        AK  # 這里是一開(kāi)始截圖用紅色圈起來(lái)的部分
    )
    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)用

傳入兩個(gè)地點(diǎn)名,返回兩地點(diǎn)距離,當(dāng)某個(gè)地點(diǎn)查詢不到時(shí),返回結(jié)果設(shè)置為-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.進(jìn)行簡(jiǎn)單的功能測(cè)試

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

5.對(duì)Excel中的批量地點(diǎn)計(jì)算距離

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

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=["起點(diǎn)", "終點(diǎn)", "距離"],
        index=None,
        encoding="utf-8"
    )

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


對(duì)應(yīng)的輸出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=全國(guó)output=jsonak={}".format(
        address,
        AK  # 這里是一開(kāi)始截圖用紅色圈起來(lái)的部分
    )
    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  # 這里是一開(kāi)始截圖用紅色圈起來(lái)的部分
    )
    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=["起點(diǎn)", "終點(diǎn)", "距離"],
        index=None,
        encoding="utf-8"
    )

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

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

標(biāo)簽:盤錦 西寧 上饒 佳木斯 珠海 宜昌 湖北 潮州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python利用百度地圖獲取兩地距離(附demo)》,本文關(guān)鍵詞  Python,利用,百度,地圖,獲取,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Python利用百度地圖獲取兩地距離(附demo)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Python利用百度地圖獲取兩地距離(附demo)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产精品久久久久久久蜜臀 | 日韩天堂在线观看| 亚洲免费av观看| 91丝袜高跟美女视频| 亚洲免费观看高清| 欧美日韩的一区二区| 奇米影视7777精品一区二区| 日韩一区二区在线观看视频| 蜜臀久久久久久久| 久久天天做天天爱综合色| 国产精品91xxx| 亚洲乱码国产乱码精品精小说 | 中文字幕一区二区三区不卡 | 中文字幕日韩欧美一区二区三区| 国产不卡视频在线播放| 亚洲日本丝袜连裤袜办公室| 欧美三级日韩三级| 久久99久久99| 最新国产成人在线观看| 欧美日本一区二区三区| 久久99精品久久只有精品| 国产精品视频一二三| 欧美日韩久久久| 国产美女精品人人做人人爽| 亚洲免费观看高清在线观看| 欧美久久久久久久久中文字幕| 国产综合一区二区| 亚洲精品视频观看| 欧美大片一区二区| 91麻豆国产福利精品| 丝袜美腿成人在线| 国产精品色在线| 欧美一区二区三区影视| 97久久超碰国产精品| 美女网站在线免费欧美精品| 中文字幕中文乱码欧美一区二区| 91精品国产麻豆| 色综合久久久久综合99| 精品在线你懂的| 亚洲国产欧美在线| 中文字幕av一区二区三区免费看| 欧美另类高清zo欧美| 99热这里都是精品| 国内精品自线一区二区三区视频| 亚洲一区二区三区国产| 国产精品污网站| 日韩你懂的在线播放| 欧美中文字幕亚洲一区二区va在线| 国产一区二区按摩在线观看| 午夜久久电影网| 亚洲色图丝袜美腿| 中文字幕第一区综合| 日韩欧美中文字幕公布| 欧美亚洲愉拍一区二区| 成人丝袜18视频在线观看| 精品一区二区三区在线播放视频| 亚洲午夜激情网站| 中文字幕一区二区三区四区不卡 | 丰满亚洲少妇av| 奇米色一区二区三区四区| 亚洲欧美日韩国产一区二区三区| 久久免费视频一区| 8x福利精品第一导航| 欧美丝袜第三区| 色狠狠综合天天综合综合| 成人在线一区二区三区| 国产成a人亚洲| 国产专区综合网| 国产美女娇喘av呻吟久久| 激情文学综合插| 国内偷窥港台综合视频在线播放| 麻豆国产精品一区二区三区| 视频一区欧美日韩| 午夜精品一区二区三区三上悠亚| 亚洲美女屁股眼交3| 综合av第一页| 亚洲欧美另类图片小说| 亚洲特黄一级片| ...av二区三区久久精品| 亚洲欧美一区二区三区孕妇| 自拍视频在线观看一区二区| 日韩理论片在线| 亚洲综合一二三区| 偷拍与自拍一区| 久久99国产精品久久99| 久久国产精品免费| 国产最新精品免费| 成人动漫av在线| 日本精品视频一区二区| 欧美色视频在线| 欧美一卡2卡三卡4卡5免费| 日韩欧美激情在线| 亚洲精品在线免费观看视频| 欧美国产综合一区二区| 亚洲欧美日韩国产中文在线| 亚洲五码中文字幕| 日韩1区2区3区| 国产风韵犹存在线视精品| 成人激情综合网站| 在线免费观看日本欧美| 日韩欧美一级在线播放| 久久日韩精品一区二区五区| 国产精品毛片a∨一区二区三区| 中文字幕一区二区三区蜜月| 亚洲欧美日韩综合aⅴ视频| 亚洲香肠在线观看| 国内久久精品视频| 色综合中文综合网| 亚洲天堂精品视频| 亚洲尤物在线视频观看| 日本午夜一本久久久综合| 国产一区二区视频在线播放| 91在线观看高清| 欧美日韩一区中文字幕| 久久亚洲精精品中文字幕早川悠里 | 欧洲国产伦久久久久久久| 91精品一区二区三区久久久久久 | 亚洲欧洲色图综合| 天天综合色天天| 国产精品1区2区| 欧美剧在线免费观看网站| 国产三区在线成人av| 亚洲一区av在线| 高清国产一区二区| 欧美精品在线视频| 国产精品不卡在线观看| 老司机精品视频在线| 一本久道中文字幕精品亚洲嫩| 精品福利在线导航| 亚洲bt欧美bt精品| 国产91精品一区二区麻豆亚洲| 欧美日韩国产中文| 日韩理论片在线| 国产成人免费高清| 日韩美女天天操| 亚洲网友自拍偷拍| 99re热这里只有精品视频| 精品日产卡一卡二卡麻豆| 亚洲国产aⅴ成人精品无吗| 高清国产一区二区三区| 欧美一区日本一区韩国一区| 一区二区激情视频| av电影在线观看一区| 国产日韩综合av| 久久精品国产亚洲一区二区三区| 欧美色图片你懂的| 一区二区欧美精品| 91亚洲国产成人精品一区二区三 | 国产福利精品一区| 精品免费一区二区三区| 日本亚洲一区二区| 欧美日韩一区不卡| 一区二区三区四区在线| 91麻豆国产自产在线观看| 中文字幕在线一区二区三区| 风间由美中文字幕在线看视频国产欧美 | 国产一区二区精品久久91| 日韩免费视频线观看| 日韩电影免费一区| 欧美日韩在线综合| 午夜精品久久久久久久蜜桃app| 91久久精品一区二区三| 亚洲欧洲制服丝袜| 91论坛在线播放| 亚洲女同一区二区| 在线视频你懂得一区二区三区| 亚洲精品国产高清久久伦理二区| 91在线观看下载| 樱花影视一区二区| 欧美午夜视频网站| 五月天亚洲精品| 欧美一级日韩一级| 国产一区二区精品在线观看| 久久精品免费在线观看| 国产成a人亚洲| 亚洲品质自拍视频网站| 欧美日韩在线不卡| 日韩在线一二三区| 欧美大白屁股肥臀xxxxxx| 精品一区二区在线视频| 国产亚洲制服色| 99久久精品国产一区二区三区| 亚洲日本va午夜在线影院| 欧美日韩国产中文| 狂野欧美性猛交blacked| 久久嫩草精品久久久久| 97精品视频在线观看自产线路二| 亚洲在线观看免费视频| 精品少妇一区二区三区免费观看| 国产一区二区精品久久99| |精品福利一区二区三区| 欧美视频一区二区在线观看| 日本欧美在线观看| 亚洲国产精品成人综合| 欧美日韩一区视频| 国产一区二区三区免费播放| 中文字幕欧美一| 欧美一区二区三区日韩视频| 高清beeg欧美| 亚洲成av人片观看|