一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - Python利用百度地圖獲取兩地距離(附demo)

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

2021-12-12 22:13Gavin_Sunny Python

本文主要介紹了Python利用百度地圖獲取兩地距離,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

百度地圖開放平臺

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

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

介紹需要用到的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碼。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
def getPosition(address):
    url = r"http://api.map.baidu.com/place/v2/search?query={}&region=全國&output=json&ak={}".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碼。

?
1
2
3
4
5
6
7
8
9
10
11
def getDistance(start, end):
    url = "http://api.map.baidu.com/routematrix/v2/driving?output=json&origins={}&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。

?
1
2
3
4
5
6
7
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.進行簡單的功能測試

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

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

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
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文件的內容為:

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

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

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

附錄

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
# 本次整體的源代碼
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=json&ak={}".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=json&origins={}&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 百度地圖獲取兩地距離 內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/Gavin_Nicholas/article/details/118581961

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 91精品手机国产在线观 | 国内自拍第1页 | 超碰97| 国产99re在线观看69热 | 思思99热久久精品在2019线 | 精品日产1区2卡三卡麻豆 | 久久精品一区二区三区资源网 | 欧美三级免费观看 | 羞羞污视频 | 青青青在线视频 | 性美国人xxxxx18 | 古装一级毛片 | 免费国产成人高清视频网站 | 成人国产第一区在线观看 | 把内裤拔到一边高h1v1 | 深夜在线看 | 欧洲第一区第二区第三区 | 精品一区二区免费视频蜜桃网 | 特黄特色大片免费高清视频 | 日本精品一区二区在线播放 | 女上男下gifxxoo动态视频 | 国产清纯女高中生在线观看 | 亚洲精品卡1卡二卡3卡四卡 | 国产最强大片免费视频 | 四虎免费在线观看 | aⅴ视频在线免播放观看 | 色综合久久六月婷婷中文字幕 | 成人午夜毛片 | 色婷婷综合久久久 | 国产香蕉一区二区在线观看 | 日本黄色录像视频 | 超兴奋朋友的中文字幕下 | 青青在线香蕉国产精品 | 天天爽天天操 | 久久精品国产久精国产果冻传媒 | 日韩影院在线观看 | 动漫美女强行被吸乳做羞羞事 | 亚州第一页 | 欧美亚洲免费 | 久久www免费人成_看片高清 | 日韩精品中文字幕视频一区 |