文档章节

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

漫步海边小路
 漫步海边小路
发布于 06/23 14:31
字数 479
阅读 25
收藏 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

没有更多内容

加载失败,请刷新页面

加载更多

Spring Boot 使用parent方式引用时 获取值属性方式默认@

采用官网提供的 引入依赖时,application.properties中的值变量,无法通过${}获取,这是由于Spring Boot 已经将字符方式调整为 <resource.delimiter>@</resource.delimiter>。故如果在,工程中...

翱翔fly
20分钟前
1
0
HTTPS证书验证流程及SSL证书生成步骤【附nginx开启https配置】

------------------------------------------------------------ HTTPS证书验证流程(极简化版) 1.客户端向服务端请求证书(server.crt) 2.服务端下发证书(server.crt) 3.客户端用预制的...

xiaomin0322
21分钟前
1
0
预编译sql语句和参数化sql能有效防止——sql注入攻击——

预编译和参数化处理sql原理类似: 参数化处理sql 是将参数进行了字符串化处理,把参数中的单引号,井号#,等都做了转义处理,进而在执行sql语句时不会被当做sql中的定界符和指定符来执行。 ...

fang_faye
22分钟前
1
0
springboot最全配置解释

​​​​​​​# ----------------------------------------# 核心属性# ----------------------------------------# 文件编码banner.charset= UTF-8# 文件位置banner.locati...

废柴大叔
23分钟前
82
1
(大致了解下)从单机到2000万QPS: 知乎Redis平台发展与演进之路

导读:知乎存储平台团队基于开源Redis 组件打造的知乎 Redis 平台,经过不断的研发迭代,目前已经形成了一整套完整自动化运维服务体系,提供很多强大的功能。本文作者是是该系统的负责人,文...

Ocean_K
31分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部