如題简肴,先上效果圖:
image.png
主要分為兩大步驟
- 使用python語句,通過百度地圖API唇聘,對已知的地名抓取經緯度
- 使用百度地圖API官網的html例程,修改數據部分柱搜,實現(xiàn)呈現(xiàn)效果
一迟郎、使用python語句,通過百度地圖API聪蘸,獲取經緯度
1. 讀取文件信息
import pandas as pd
data = pd.read_excel('test_baidu.xlsx')
data
image.png
圖中可以看出宪肖,原始數據并沒有經緯度。
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,'圈定區(qū)域'])
get_lat = get_location[0]
get_lng = get_location[1]
data.loc[indexs,'緯度'] = get_lat
data.loc[indexs,'經度'] = get_lng
data
image.png
已經自動查找到對應的經緯度(不排除部分搜索不準衷咽,但是大概看過鸽扁,還是挺準的。)
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,'圈定區(qū)域']) +'"' + \
'}' + ','
data_html.to_csv ("data_html.csv",encoding="gbk")
data_html
image.png
生成對應的格式镶骗,然后就copy出來了。
二躲雅、使用百度地圖API官網的html例程鼎姊,修改數據部分,實現(xiàn)呈現(xiàn)效果
1. copy百度地圖API官網的HTML例程
地址:http://developer.baidu.com/map/jsdemo.htm#c1_19
image.png
2. 修改部分內容
- 放上自己的百度地圖AK
- 修改一下地圖初始化顯示的中心和縮放的系數
- 放上自己需要顯示的信息相赁,記得把數據中最后一個的逗號刪除
修改前:
image.png
修改后:
image.png
題外:
其實一開始是使用folium進行嘗試的相寇,因為可以直接生成html文件,只需要Python就行了钮科,不需要再寫HTML唤衫,但是遇到兩個暫時無法解決的問題:
-
marker不能正常顯示,官網的marker都不行
圖片.png -
openstreetmap的細致程度绵脯,比不上百度地圖佳励,這個有點致命。
圖片.png