文章目录
一、简介
通过百度开发平台提供的行政区划地址,通过python的方式获取数据,并将数据转化成需求的格式
- 202402191052更新内容,发现香港澳门的level格式和其他地区的格式不同,特根据JSON的结构重新生成level来统一格式。同时,将导出的excel加上时间戳,以保证每次导出都有一份记录。
二、需求格式
1.省市区的对应关系格式
结果展示:
代码如下:
import json
import pandas as pd
import requests
# 接口地址
url = "https://api.map.baidu.com/api_region_search/v1/"
# 此处填写你在控制台-应用管理-创建应用后获取的AK
ak = "xxxxxxxxxxxxx"
params = {
"keyword": "全国",
"sub_admin": "3",
"ak": ak,
"extensions_code": "1",
}
response = requests.get(url=url, params=params)
data = json.loads(response.text)
# if response:
# print(response.json())
# 因为香港澳门的省市县的level有点不对,所以需要根据JSON更新一下level。以保证是以省嵌套市嵌套县……的格式
def set_level(districts, level=0):
for district in districts:
district['level'] = level
set_level(district.get('districts', []), level + 1)
set_level(data['districts'])
# 提取省份和市区信息,并生成对应关系
provinces_cities = []
for dist in data['districts']:
if dist['level'] == 0: # 全国
for district in dist['districts']:
if district['level'] == 1: # 省份级别
for sub_district in district['districts']:
if sub_district['level'] == 2: # 市级别
for sub_sub_district in sub_district['districts']:
if sub_sub