Python通过高德API获取全国省市区行政区边界

引文

由于项目需求,需要获取全国的省市区三级行政区边界。而随着历史变迁和各种人文、政治、发展、规划等因素,各级行政区的辖区都在发生变化,那么对于静态的行政边界矢量包很有可能会由于时效性导致无法及时更新而出现偏差。本文使用Python通过高德API实时获取全国省市区三级行政区的边界,可以保证准确性和时效性的要求。
在这里插入图片描述

1. 导入相关依赖库

import requests
import pandas as pd
import json
from tqdm import tqdm

2. 获取省市区三级行政区边界数据

# 查询当前行政区及下三级行政区
def search_district(keywords):
    key = 'xxxxxxxxxx'  # 替换为你的高德API key
    url = 'https://restapi.amap.com/v3/config/district'
    params = {'keywords': keywords, 'subdistrict':3, 'extensions':'all', 'key': key}
    headers={'User-Agent':'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/94.0.4606.81 Safari/537.36'}
    response = requests.get(url=url, params=params, headers=headers, timeout=3)
    res = json.loads(response.text)['districts']
    return res

# 获取省市区三级行政区划分信息
data = search_district('中华人民共和国')
concat_list = []
def process_data(data):
    df_tmp = pd.DataFrame(data)
    concat_list.append(df_tmp)
    for area in data:
        if area['districts'] == []:
            continue
        df_tmp = pd.DataFrame(area['districts'])
        concat_list.append(df_tmp)
        process_data(area['districts'])
process_data(data)
df = pd.concat(concat_list).drop_duplicates(subset='adcode')

# 获取polyline和下属行政区划分
concat_list_2 = [pd.DataFrame(search_district(adcode)) for adcode in tqdm(df['adcode'].values)]
df2 = pd.concat(concat_list_2).drop_duplicates(subset='adcode').drop(columns=['districts']).sort_values(by='adcode').reset_index(drop=True)
df2.to_json(path_or_buf='高德中国省市区行政边界数据.json',orient="records",force_ascii=False)

运行结果:
在这里插入图片描述
文件保存为json格式,因为由于边界数据过长,若保存为csvxlsx表格文件格式,会发生数据截断而造成数据丢失,而在json格式下可以保证数据的完整性。

3. 展示边界形状

from shapely import wkt

def polyline2polygon(polyline):       #  将polyline转化为polygon格式
    if '|' in polyline:
        poly_list = polyline.split('|')
        return 'MULTIPOLYGON(' + ','.join(map(lambda x:'(('+x.replace(',',' ').replace(';',',')+'))',poly_list)) + ')'
    else:
        return 'POLYGON((' + polyline.replace(',',' ').replace(';',',') + '))'

# 北京市行政区边界
polyline = df2['polyline'].values[1]
polygon = polyline2polygon(polyline)
wkt.loads(polygon)

在这里插入图片描述

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
根据百度API获取经纬度对应的省市区信息,可以使用Python进行实现。以下是一个示例代码: ```python import requests def get_location_info(latitude, longitude): ak = '你的百度开发API密钥' # 需要替换为自己的百度开发API密钥 url = f'http://api.map.baidu.com/reverse_geocoding/v3/?ak={ak}&output=json&coordtype=wgs84ll&location={latitude},{longitude}' response = requests.get(url) data = response.json() if data['status'] == 0: province = data['result']['addressComponent']['province'] city = data['result']['addressComponent']['city'] district = data['result']['addressComponent']['district'] return province, city, district else: return None # 使用示例 latitude = 39.9087 # 纬度 longitude = 116.3975 # 经度 location_info = get_location_info(latitude, longitude) if location_info: province, city, district = location_info print(f'该经纬度所在位置为:省份:{province},城市:{city},区县:{district}') else: print('获取位置信息失败') ``` 以上代码中,我们使用了Python的requests库发送HTTP请求,并通过百度API的逆地理编码接口获取经纬度对应的位置信息。需要注意,你需要将`ak`变量的值替换为自己的百度开发API密钥。 具体步骤为: 1. 引入requests库,用于发送HTTP请求。 2. 定义一个`get_location_info`函数,该函数接受经度和纬度作为参数,并返回省市区的信息。 3. 在函数中构建请求URL,包括百度API密钥、经纬度等信息,并发送GET请求获取响应数据。 4. 解析API返回的JSON数据,提取省市区信息。 5. 在主程序中,调用`get_location_info`函数,传入经纬度参数,获取位置信息。 6. 如果成功获取位置信息,则将其打印出来;否则输出获取位置信息失败的提示。 注意,以上代码仅为示例,具体的实现需要根据你所使用的具体百度API接口和参数进行适当的调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值