如題,先上效果圖:
主要分為兩大步驟使用python語句,通過百度地圖API,對已知的地名抓取經緯度
使用百度地圖API官網的html例程,修改數據部分,實現呈現效果
一、使用python語句,通過百度地圖API,獲取經緯度讀取文件信息
python函數調用另一個函數,import pandas as pd
data = pd.read_excel('test_baidu.xlsx')
data
圖中可以看出,原始數據并沒有經緯度。
java python?2. 構建抓取經緯度函數
import json
from urllib.request import urlopen, quote
import requests
python全局變量、def getlnglat(address):
url = 'http://api.map.baidu.com/geocoder/v2/'
output = 'json'
ak = '你的百度地圖ak' # 百度地圖ak,具體申請自行百度,提醒需要在“控制臺”-“設置”-“啟動服務”-“正逆地理編碼”,啟動
python調用。address = quote(address) # 由于本文地址變量為中文,為防止亂碼,先用quote進行編碼
uri = url + '?' + 'address=' + address + '&output=' + output + '&ak=' + ak
req = urlopen(uri)
res = req.read().decode()
java 調用python,temp = json.loads(res)
lat = temp['result']['location']['lat']
lng = temp['result']['location']['lng']
return lat,lng # 緯度 latitude , 經度 longitude ,
python調用c語言、3. 抓取經緯度
for indexs in data.index:
get_location = getlnglat(data.loc[indexs,'圈定區域'])
get_lat = get_location[0]
python調用方法、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的細致程度,比不上百度地圖,這個有點致命。
版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。
工作时间:8:00-18:00
客服电话
电子邮件
admin@qq.com
扫码二维码
获取最新动态