文档章节

行政区划代码转为字典形式

漫步海边小路
 漫步海边小路
发布于 06/23 14:31
字数 479
阅读 34
收藏 0

原数据为: http://www.mca.gov.cn/article/sj/xzqh/2018/201804-12/201804-06041553.html

手动替换了一下格式,注意有些省直属县(第三位为9的)需要手动处理一下,并使用下面的代码处理.

# 输入格式
s = """
110000:北京市
110101:东城区
110102:西城区
110105:朝阳区
110106:丰台区
110107:石景山区
110108:海淀区
110109:门头沟区
110111:房山区
110112:通州区
110113:顺义区
110114:昌平区
110115:大兴区
110116:怀柔区
110117:平谷区
110118:密云区
110119:延庆区
"""
slist = s.split("\n")

province_code = ""  # 省级单位的代码
city_code = ""  # 市级单位的代码
province_name = ""  # 省级单位的名字
city_name = ""  # 市级单位的名字
res = {}  # 要数出的结果

for index, i in enumerate(slist):
    if not i:
        continue
    i = i.split(":")
    code = i[0]
    name = i[1]
    _province_code = code[0:2]

    if _province_code != province_code and code.endswith("0000"):  # 省级代码以 0000 结尾
        province_code = _province_code
        province_name = name
        city_code = ""  # 清空市的信息
        city_name = ""  # 清空市的信息
        res[name] = {'code': code}  # 添加省的字典
    else:  # 遍历市
        _city_code = code[2:4]
        if _city_code != city_code and code.endswith("00"):  # 省级代码以 0000 结尾
            city_code = _city_code
            city_name = name
            res[province_name][city_name] = {'code': code}  # 添加市的字典
        else: # 遍历县
            print(province_name, city_name, name)
            if city_name:
                res[province_name][city_name][name] = {'code': code}  # 添加县的字典
            elif name:
                res[province_name][name] = {'code': code}  # 添加县的字典,直辖市的

处理结果为:

{
	"北京市": {
		"code": "110000",
		"东城区": {
			"code": "110101"
		},
		"西城区": {
			"code": "110102"
		},
		"朝阳区": {
			"code": "110105"
		},
		"丰台区": {
			"code": "110106"
		},
		"石景山区": {
			"code": "110107"
		},
		"海淀区": {
			"code": "110108"
		},
		"门头沟区": {
			"code": "110109"
		},
		"房山区": {
			"code": "110111"
		},
		"通州区": {
			"code": "110112"
		},
		"顺义区": {
			"code": "110113"
		},
		"昌平区": {
			"code": "110114"
		},
		"大兴区": {
			"code": "110115"
		},
		"怀柔区": {
			"code": "110116"
		},
		"平谷区": {
			"code": "110117"
		},
		"密云区": {
			"code": "110118"
		},
		"延庆区": {
			"code": "110119"
		}
	},
}

© 著作权归作者所有

共有 人打赏支持
漫步海边小路
粉丝 1
博文 64
码字总数 12426
作品 1
威海
人事招聘
私信 提问
Winform开发框架之字典管理模块的更新,附上最新2013年全国最新县及县以上行政区划代码sql脚本

在很多项目里面,字典管理是必备的项目模块,而这个又是比较通用的功能,因此可以单独做成一个通用字典管理,例如这个模块,可以通过集成的方式,使用在我的《Winform开发框架》、《WCF开发框...

walb呀
2017/12/04
0
0
总结几个有关国家行政区划的问题

(本文仅作抛砖引玉之用,如诸位有更好的观点或方法可在本博客下方留言,谢谢) 如果填写表单时国家行政区划数据并非手工填写,而是依靠级联菜单或弹窗选择,就会有一些问题,主要涉及以下三...

北风其凉
2016/10/11
65
0
input搜索下拉提示框,支持拼音检索、过滤、级联、自定义数据源的ajax异步下拉展示

为解决大数据量下拉字典效率及操作问题,整理出通用的数据字典模块,所有字典数据可在数据库维护,在大数据量时采用分页下拉的展示方式,同时支持拼音简拼搜索,代码项、代码值搜索等,支持无...

神话无名
06/07
0
0
Go 语言实现的中国行政区划代码包 - gbt2260

中国行政区划代码 中华人民共和国县以上行政区划代码的golang包 安装 go get github.com/ppmoon/gbt2260 或者你使用vgo vgo get github.com/ppmoon/gbt2260 如何使用? 输入一个行政区域代码...

ppmoon
06/13
0
0
Neo4j & Python 构建中国行政区划图

哇标题看起来挺厉害的,其实没有很难啦,而且非常有趣。 我为什么要做这个 我本人就很讨厌看到这种标题——我为什么xxx?喵喵喵?你为什么xxx关我什么事?唉,人总是会变成自己讨厌的人嘛。 ...

pujiaxun
2017/11/10
0
0

没有更多内容

加载失败,请刷新页面

加载更多

mysql load data 批量导入使用

最近在研究使用mycat,其中有使用批量数据导入,简单记录一下使用方式。 查看系统属性 mysql>show variables like '%secure%'+--------------------------+-----------------------+| Vari...

FansinZhao
18分钟前
0
0
浅谈React的最大亮点——虚拟DOM

在Web开发中,需要将数据的变化实时反映到UI上,这时就需要对DOM进行操作,但是复杂或频繁的DOM操作通常是性能瓶颈产生的原因,为此,React引入了虚拟DOM(Virtual DOM)的机制。 一、什么是...

peakedness丶
21分钟前
0
0
下一代大数据处理引擎,阿里云实时计算独享模式重磅发布

摘要: 11月14日,阿里云重磅发布了实时计算独享模式,即用户独享一部分物理资源,这部分资源在网络/磁盘/CPU/内存等资源上跟其他用户完全独立,是实时计算在原有共享模式基础上的重大升级。...

阿里云官方博客
26分钟前
0
0
Spring MVC 测试样例

1、需要javax.servlet-api V3.0以上支持 <!--3.0以上版本--> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-......

jcc_codingBoy
28分钟前
2
0
kettle增量同步oracle数据到mysql

kettle增量同步oracle数据到mysql 适合表中有更新时间的字段 kettle安装 绿色,下载后解压即可(略), -> Download 连接数据库 需要导入jdbc相关驱动jar包到lib目录(oracle、mysql对应jar...

o00o
33分钟前
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部