1. 程式人生 > >python3 通過百度地圖API獲取城市POI點並存於CSV格式

python3 通過百度地圖API獲取城市POI點並存於CSV格式

原文資訊:

作者: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 requests

import pandas as pd

left_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).text

            print(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:break
            
        n += 1;
        print ('第',str(n),'個切片入庫成功')
feature=pd.DataFrame(feature_data)
feature.to_csv('data/Graden.csv')