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

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

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

熱門標簽:銀川電話機器人電話 預覽式外呼系統 企業彩鈴地圖標注 上海正規的外呼系統最新報價 電銷機器人錄音要學習什么 長春極信防封電銷卡批發 外賣地址有什么地圖標注 如何地圖標注公司 煙臺電話外呼營銷系統

百度地圖開放平臺

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

介紹需要用到的API

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

1.地點檢索服務

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

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

2.批量算路服務

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

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

編寫Python程序

0.需要用到的模塊

  •  requests
  • json

1.獲取對應地點的經緯度

將傳入的address通過地點檢索服務得到其經緯度,返回值為經緯度對應的字符串值,中間以逗號隔開,之后跟一個查詢返回狀態,如果查詢失敗,狀態值不為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"]  # 經度
    else:
        print("[ERROR] Can not find {}.".format(address))
        return "0,0", json_data["status"]
    return str(lat) + "," + str(lng), json_data["status"]

2.獲取兩地之間的距離

將傳入的兩個地點(以經緯度描述)通過批量算路服務得到之間的路線規劃距離。本范例是以駕車行駛(對應參數為'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.合并函數調用

傳入兩個地點名,返回兩地點距離,當某個地點查詢不到時,返回結果設置為-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文件的內容為:


對應的輸出result.xlsx文件內容如下:

附錄

# 本次整體的源代碼
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"]  # 經度
    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 百度地圖獲取兩地距離 內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

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

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

巨人網絡通訊聲明:本文標題《Python利用百度地圖獲取兩地距離(附demo)》,本文關鍵詞  Python,利用,百度,地圖,獲取,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Python利用百度地圖獲取兩地距離(附demo)》相關的同類信息!
  • 本頁收集關于Python利用百度地圖獲取兩地距離(附demo)的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产高清精品网站| 亚洲精品中文字幕乱码三区| 午夜精品福利一区二区蜜股av| 精品国产乱码久久久久久图片| 国产精品色噜噜| 欧美日本国产一区| 色偷偷一区二区三区| 国产精品一区二区久激情瑜伽| 蜜臀av性久久久久蜜臀av麻豆| 中文字幕在线观看一区二区| 国产区在线观看成人精品| 久久一留热品黄| 国产精品乱码妇女bbbb| 亚洲日本丝袜连裤袜办公室| 亚洲免费观看高清在线观看| 一区二区理论电影在线观看| 亚洲欧洲日韩av| 国产精品久久久久久久久免费丝袜 | 国产精品大尺度| 亚洲午夜免费视频| 自拍偷拍亚洲综合| 亚洲欧洲99久久| 午夜在线电影亚洲一区| 日韩av中文在线观看| 极品少妇一区二区| 国产亚洲午夜高清国产拍精品 | 亚洲欧美电影一区二区| 亚洲免费毛片网站| 午夜影院久久久| 国产盗摄精品一区二区三区在线| 91丨porny丨蝌蚪视频| 欧美一级理论性理论a| 国产精品网曝门| 国产综合色精品一区二区三区| 亚洲天天做日日做天天谢日日欢| 一个色妞综合视频在线观看| 精品亚洲aⅴ乱码一区二区三区| 成人一区二区三区在线观看| 狠狠久久亚洲欧美| 亚洲最大的成人av| 蜜桃视频在线观看一区| 亚洲免费观看在线观看| 亚洲欧美日韩国产综合在线| 福利视频网站一区二区三区| 老司机午夜精品99久久| 亚洲女同女同女同女同女同69| 欧美日韩你懂的| 国产毛片一区二区| 成人一级视频在线观看| 亚洲丝袜精品丝袜在线| 五月婷婷色综合| 国产久卡久卡久卡久卡视频精品| 精品视频在线免费看| 91福利在线导航| 欧美一a一片一级一片| 国产jizzjizz一区二区| 紧缚奴在线一区二区三区| 91视频免费观看| 国产一区二区三区四| 国产福利视频一区二区三区| 热久久一区二区| 国产尤物一区二区| 精品在线亚洲视频| 国产美女在线精品| 亚洲国产精品欧美一二99| 三级在线观看一区二区| 欧美午夜精品一区二区蜜桃| 亚洲免费资源在线播放| 懂色av一区二区夜夜嗨| 精品久久久久久久人人人人传媒| 激情综合色丁香一区二区| 亚洲va欧美va天堂v国产综合| 色94色欧美sute亚洲线路一ni | 亚洲va国产天堂va久久en| 午夜精品视频在线观看| 中文字幕在线一区二区三区| 亚洲国产三级在线| 处破女av一区二区| 欧美日韩一区三区| 久久青草欧美一区二区三区| 日韩不卡一区二区三区| 91在线精品一区二区三区| 欧美大胆人体bbbb| 一区二区三区国产豹纹内裤在线| 国产一区二区三区香蕉| 欧美日韩国产综合久久| 欧美人妖巨大在线| 欧美日韩亚洲综合在线| 国产欧美一区二区精品久导航| 亚洲影视资源网| av成人免费在线观看| 精品三级在线观看| 偷偷要91色婷婷| 欧美伊人久久久久久久久影院| 国产精品免费丝袜| 国产毛片精品一区| 日韩欧美亚洲另类制服综合在线| 亚洲电影你懂得| 在线看国产日韩| 亚洲精品乱码久久久久久日本蜜臀| 国产成人av一区二区| 久久一区二区三区国产精品| 狠狠色丁香久久婷婷综合丁香| 日韩午夜电影av| 久久99精品久久久久久国产越南| 91精品免费在线观看| 天天操天天干天天综合网| 欧美色视频一区| 午夜国产精品一区| 制服丝袜亚洲播放| 六月丁香婷婷色狠狠久久| 欧美一区二区三区四区五区 | 国产欧美一区视频| 国产一区二区伦理片| 久久久久久一级片| 成人av在线播放网站| 中文字幕亚洲电影| 欧洲国产伦久久久久久久| 亚洲观看高清完整版在线观看| 欧美日韩精品一区二区三区| 免费欧美在线视频| 久久精品一区二区| caoporen国产精品视频| 亚洲一区二区视频在线| 日韩欧美成人一区二区| 国产成人一区在线| 亚洲欧美日韩系列| 678五月天丁香亚洲综合网| 麻豆精品国产传媒mv男同| 国产女同性恋一区二区| 91亚洲永久精品| 日日嗨av一区二区三区四区| 日韩片之四级片| 成人一区二区三区视频| 亚洲成a天堂v人片| 精品少妇一区二区三区在线视频| 亚洲乱码日产精品bd| 欧美男女性生活在线直播观看| 日本成人在线网站| 国产精品青草久久| 91麻豆精品国产91久久久资源速度| 日韩av一区二| 欧美日韩性生活| 国产激情一区二区三区四区| 一区二区三区日韩在线观看| 欧美一区午夜视频在线观看| 粉嫩高潮美女一区二区三区| 一区二区三区四区蜜桃| 国产日韩欧美精品在线| 欧美视频在线观看一区| 国产成人精品三级| 日韩成人免费在线| 亚洲色图清纯唯美| 国产午夜一区二区三区| 91久久精品国产91性色tv| 精品国产一区a| 色一情一伦一子一伦一区| 欧美a级理论片| 欧美午夜电影网| 午夜精品福利久久久| 欧美日韩一区二区三区在线看 | 亚洲午夜影视影院在线观看| 91啪亚洲精品| 精品系列免费在线观看| 欧美人与z0zoxxxx视频| 中文字幕一区二区三区不卡| 日韩欧美中文一区二区| 欧美私人免费视频| 不卡电影免费在线播放一区| 久久se精品一区二区| 日本一区中文字幕| 亚洲一区二区综合| 亚洲精品成人a在线观看| 亚洲国产精品v| 国产婷婷一区二区| 亚洲精品一区二区在线观看| 日韩欧美一卡二卡| 欧美一区二区福利视频| 91精品国产色综合久久ai换脸| 欧美综合一区二区| 日本高清无吗v一区| 91在线云播放| 亚洲制服丝袜在线| 欧美日韩的一区二区| av欧美精品.com| 成人激情电影免费在线观看| 午夜精品久久久| 亚洲综合男人的天堂| 亚洲一区二区高清| 亚洲免费电影在线| 亚洲国产成人av好男人在线观看| 日韩理论片一区二区| 洋洋成人永久网站入口| 中文字幕免费一区| 亚洲另类在线制服丝袜| 亚洲高清免费一级二级三级| 一区二区三区日本| 日本不卡一二三区黄网| 五月天激情综合| 国产米奇在线777精品观看|