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

本文介绍了如何利用Python和高德API获取全国省市区三级行政区的实时边界数据,确保准确性和时效性,最后以json格式保存结果,避免数据丢失。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

引文

由于项目需求,需要获取全国的省市区三级行政区边界。而随着历史变迁和各种人文、政治、发展、规划等因素,各级行政区的辖区都在发生变化,那么对于静态的行政边界矢量包很有可能会由于时效性导致无法及时更新而出现偏差。本文使用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)

在这里插入图片描述

### 获取中国各省市区的地图数据及对应经纬度坐标的解决方案 在前端开发中,地图数据展示是一个常见的需求。为了实现这一目标,开发者通常需要获取并处理地理空间数据,其中包括省份、城市、区县的边界信息以及其对应的经纬度坐标。 #### 地图数据来源 可以利用公开的数据集来获取中国的行政区划及其经纬度信息。这些数据一般以GeoJSON或Shapefile格式提供,能够被大多数现代GIS软件和Web框架解析。例如,在线平台如GitHub上存在许多开源项目专门整理了此类资源[^1]。 #### 工具推荐 对于快速获取特定区域内的多个地点(比如省市区县级别的中心点)的精确位置即经纬度而言,“轨迹经纬度拾取系统”是一种非常实用的选择。该工具允许用户直观地选取兴趣点,并自动记录下它们的确切地理位置参数——经度与纬度值组合而成的一组数值对儿。 #### 技术实现方式 如果希望进一步定制化自己的应用,则可以通过编程手段调用第三方API服务完成相同目的。以下是基于Python语言的一个简单示例程序片段用于演示如何批量查询地址转为地理编码的过程: ```python import requests def get_geocode(address): url = f'https://restapi.amap.com/v3/geocode/geo?address={address}&key=YOUR_API_KEY' response = requests.get(url).json() if 'geocodes' in response and len(response['geocodes']) > 0: location = response['geocodes'][0]['location'] lng, lat = map(float, location.split(',')) return {'lng': lng, 'lat': lat} else: raise ValueError(f"No geocode found for {address}") addresses = ["北京市", "上海市"] results = [] for addr in addresses: try: result = get_geocode(addr) results.append(result) except Exception as e: print(e) print(results) ``` 此脚本依赖高德地图开放平台所提供的RESTful API接口来进行逆向地理编解码操作。注意替换`YOUR_API_KEY`为你实际申请到的有效密钥字符串之前先注册账号获得权限后再测试运行代码逻辑正确与否即可正常使用上述功能模块啦!
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值