如題,先上效果圖:
主要分為兩大步驟
使用python語句,通過百度地圖API,對已知的地名抓取經緯度
使用百度地圖API官網的html例程,修改數據部分,實現呈現效果
一、使用python語句,通過百度地圖API,獲取經緯度讀取文件信息
import pandas as pd data = pd.read_excel('test_baidu.xlsx') data
圖中可以看出,原始數據并沒有經緯度。
2. 構建抓取經緯度函數
import json from urllib.request import urlopen, quote import requests def getlnglat(address): url = 'http://api.map.baidu.com/geocoder/v2/' output = 'json' ak = '你的百度地圖ak' # 百度地圖ak,具體申請自行百度,提醒需要在“控制臺”-“設置”-“啟動服務”-“正逆地理編碼”,啟動 address = quote(address) # 由于本文地址變量為中文,為防止亂碼,先用quote進行編碼 uri = url + '?' + 'address=' + address + '&output=' + output + '&ak=' + ak req = urlopen(uri) res = req.read().decode() temp = json.loads(res) lat = temp['result']['location']['lat'] lng = temp['result']['location']['lng'] return lat,lng # 緯度 latitude , 經度 longitude ,
3. 抓取經緯度
for indexs in data.index: get_location = getlnglat(data.loc[indexs,'圈定區域']) get_lat = get_location[0] get_lng = get_location[1] data.loc[indexs,'緯度'] = get_lat data.loc[indexs,'經度'] = get_lng data
已經自動查找到對應的經緯度(不排除部分搜索不準,但是大概看過,還是挺準的。)
4. 生成HTML適配的格式
data_html = pd.DataFrame(columns=['content']) for indexs in data.index: data_html.loc[indexs,'content'] = '{' + \ '"lat":' + str(data.loc[indexs,'緯度']) + ',' + \ '"lng":' + str(data.loc[indexs,'經度']) + ',' + \ '"quyu":' + '"' + str(data.loc[indexs,'圈定區域']) +'"' + \ '}' + ',' data_html.to_csv ("data_html.csv",encoding="gbk") data_html
生成對應的格式,然后就copy出來了。
二、使用百度地圖API官網的html例程,修改數據部分,實現呈現效果1. copy百度地圖API官網的HTML例程
地址:http://developer.baidu.com/map/jsdemo.htm#c1_19
2. 修改部分內容
放上自己的百度地圖AK
修改一下地圖初始化顯示的中心和縮放的系數
放上自己需要顯示的信息,記得把數據中最后一個的逗號刪除
修改前:
修改后:
題外:
其實一開始是使用folium進行嘗試的,因為可以直接生成html文件,只需要Python就行了,不需要再寫HTML,但是遇到兩個暫時無法解決的問題:
1、marker不能正常顯示,官網的marker都不行
2、openstreetmap的細致程度,比不上百度地圖,這個有點致命。
以上所述是小編給大家介紹的利用python和百度地圖API實現數據地圖標注的方法詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
