高德地图行政区划数据获取与转换为sql
环境说明
python3即可,无其它外部依赖
项目截图
CREATE TABLE `t_district` (`id` bigint NOT NULL AUTO_INCREMENT COMMENT 'id',`pid` bigint NOT NULL DEFAULT '0' COMMENT '父级id',`name` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '名称',`adcode` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '省代码',`citycode` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '市代码',`center` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '中心经纬度',`level` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '级别',PRIMARY KEY (`id`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=3647 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='行政区划表';
使用步骤
- 获取数据,将key替换为自己在高德地图应用中申请的key。(程序内以提供可直接使用的code.json)【可跳过】
https://restapi.amap.com/v3/config/district?key=1111111&subdistrict=3&offset=999
-
接口参数参考高德地图api https://lbs.amap.com/api/webservice/guide/api/district
-
可以将key替换后,直接在浏览器中请求。得到以下截图。
-
提取内部的数据,为code.json 【可跳过】
-
执行province.py进行转换
得到 province.sql、city.sql、area.sql
总结与不足
- 完善生成的sql格式,支持自定义表结构等
- 去掉了顶层的国家
- 只保留了3级,未到乡镇
资源可自取 https://download.csdn.net/download/weixin_45978842/90052312