原文信息:
作者:WenWu_Both?
出處:http://blog.csdn.net/wenwu_both/article/?
版權:本文版權歸作者和CSDN博客共有?
轉載:歡迎轉載,但未經作者同意,必須保留此段聲明;必須在文章中給出原文鏈接;否則必究法律責任
話不多說,由于興趣,需要一些POI點的位置信息,于是找到了這篇博客,因為原作是基于python2.寫的,出于python2.和python3.的些許不同,而小編一直再用python3.,所以準備小做一波筆記。
關于API以及創建百度地圖應用可以參見原作者文章:https://blog.csdn.net/WenWu_Both/article/details/70187605,原作者大牛寫的非常詳細。
主要問題在于:
Python官方基礎模塊:urllib2 第三方功能包:requests
python 3.x中urllib庫和urilib2庫合并成了urllib庫。 其中urllib2.urlopen()變成了urllib.request.urlopen() urllib2.Request()變成了urllib.request.Request()
同時我們將獲取到的POI點信息存于CSV格式,代碼如下:
# -*- coding: utf-8 -*-
# Python 3.6
import json import requestsimport pandas as pdleft_bottom = [120.008235,30.121327]; # 設置區域左下角坐標(百度坐標系)
right_top = [120.188758,30.316061]; # 設置區域右上角坐標(百度坐標系)
part_n = 5; # 設置區域網格(5*5)url0 = 'http://api.map.baidu.com/place/v2/search?';
x_item = (right_top[0]-left_bottom[0])/part_n;
y_item = (right_top[1]-left_bottom[1])/part_n;
query = '公園'; #搜索關鍵詞設置
ak = 'XXXXXXXXXXXXXXXX'; #百度地圖api信令
n = 0; # 切片計數器
feature_data=[]
for i in range(part_n):for j in range(part_n):left_bottom_part = [left_bottom[0]+i*x_item,left_bottom[1]+j*y_item]; # 切片的左下角坐標right_top_part = [right_top[0]+i*x_item,right_top[1]+j*y_item]; # 切片的右上角坐標for k in range(20):url = url0 + 'query=' + query + '&page_size=20&page_num=' + str(k) + '&scope=1&bounds=' + str(left_bottom_part[1]) + ',' + str(left_bottom_part[0]) + ','+str(right_top_part[1]) + ',' + str(right_top_part[0]) + '&output=json&ak=' + ak; print(url)data = requests.get(url).textprint(data)hjson = json.loads(data);if hjson['message'] == 'ok':datalist=hjson['results']for each in datalist:feature_data.append(each)# feature=pd.DataFrame(feature_data)# else:breakn += 1;print ('第',str(n),'個切片入庫成功')
feature=pd.DataFrame(feature_data)
feature.to_csv('data/Graden.csv')
?