Python | 百度POI获取

2021/10/30 1:09:34

本文主要是介绍Python | 百度POI获取,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

地点检索服务
地点检索服务(又名Place API)是一类Web API接口服务;
服务提供多种场景的地点(POI)检索功能,包括城市检索、圆形区域检索、矩形区域检索。开发者可通过接口获取地点(POI)基础或详细地理信息。

百度地图服务文档

import os
import requests
import json
import time


# query	检索关键字。行政区划区域检索不支持多关键字检索。如果需要按POI分类进行检索,请将分类通过query参数进行设置,如query=美食
# tag	检索分类偏好,与q组合进行检索,多个分类以","分隔(POI分类),如果需要严格按分类检索,请通过query参数设置
# region	检索行政区划区域(增加区域内数据召回权重,如需严格限制召回数据在区域内,请搭配使用city_limit参数),可输入行政区划名或对应cityCode
# city_limit	区域数据召回限制,为true时,仅召回region对应区域内数据
# extensions_adcode   是否召回国标行政区划编码,true(召回)、false(不召回)
# output	输出格式为json或者xml
# scope	检索结果详细程度。取值为1 或空,则返回基本信息;取值为2,返回检索POI详细信息
# coord_type	坐标类型,1(wgs84ll即GPS经纬度),2(gcj02ll即国测局经纬度坐标),3(bd09ll即百度经纬度坐标),4(bd09mc即百度米制坐标)注:"ll为小写LL"
# ret_coordtype	可选参数,添加后POI返回国测局经纬度坐标
# page_size	单次召回POI数量,默认为10条记录,最大返回20条。多关键字检索时,返回的记录数为关键字个数*page_size。	int
# page_num	分页页码,默认为0,0代表第一页,1代表第二页,以此类推。常与page_size搭配使用,仅当返回结果为poi时可以翻页。
# ak	开发者的访问密钥,必填项。v2之前该属性为key。


def get_info(ak):
    # 获取poi相关信息
    info_all = []  # 用来存取未解析的数据
    page = 0  # 用于翻页
    flag = True  # 设置标志,判断是否到了页尾,用于退出循环
    while flag:
        url = 'https://api.map.baidu.com/place/v2/search?query=公园&tag=旅游景点&region=惠州市&output=json' \
              f'&ak={ak}&page_size=20&page_num={page}&scope=2&city_limit=true&coord_type=1'
        content = requests.get(url).content.decode('utf-8')  # 发送get请求,获取数据
        # JSON 数据解析:https://www.runoob.com/python3/python3-json.html
        dic = json.loads(content)  # 因为接收的数据是json字符串格式,所以把它转为字典格式
        if dic['total'] == 0:  # 若为0,说明到页尾了,将flag设为False,以退出循环
            flag = False
            continue
        info = dic['results']
        info_all = info_all + info  # 拼接列表,也就是把每页的未解析的数据加到列表里
        page += 1  # 翻页
        time.sleep(1)  # 避免程序访问百度链接出现高并发状态
        print(f"第{page}页...")
    return info_all  # 返回所有未解析的数据


def save_info(info_all):
    # 解析数据并保存信息
    path = '惠州市公园数据.txt'
    # a模式:打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
    with open(path, 'w') as f:  # 打开文件
        # 字符串 join()方法:  https://www.runoob.com/python3/python3-string-join.html
        s = '       '  # 连接符
        # 下面对应内容 纬度 经度 标签 城市 区域 地址 名称 UID 百度地图链接
        seq = s.join(['lat', 'lng', 'tag', 'city', 'area', 'address', 'name', 'uid', 'detail_url'])
        # File write() 方法: https://www.runoob.com/python3/python3-file-write.html
        f.write(seq + '\n')  # 写入文件内容
        for row in range(len(info_all)):
            # 字典:https://www.runoob.com/python3/python3-dictionary.html
            # data各个子项就是提取字典里的数据
            data = [
                str(info_all[row]['location']['lat']),
                str(info_all[row]['location']['lng']),
                info_all[row]['detail_info']['tag'],
                info_all[row]['city'],
                info_all[row]['area'],
                info_all[row]['address'],
                info_all[row]['name'],
                info_all[row]['uid'],
                info_all[row]['detail_info']['detail_url']
            ]
            line = s.join(data) + '\n'
            f.write(line)
    print("保存完毕!")


def main():
    # 主函数
    ak = input("请输入您的ak:")
    if len(ak) == 32:  # 判断输入的ak长度是否符合要求
        info_all = get_info(ak)  # 获取未解析的数据信息
        save_info(info_all)  # 解析并保存
    else:
        print("请确认Ak输入无误后,再重新尝试!")


if __name__ == '__main__':
    # 程序从这里开始运行
    main()



这篇关于Python | 百度POI获取的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程