1 Star 4 Fork 0

China-bian/全国省市区

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
makedata.py 6.55 KB
一键复制 编辑 原始数据 按行查看 历史
# -*- coding:utf-8 -*-
import json
import codecs
from collections import OrderedDict
def make_data():
source_file_list = [
'village', 'village_object', 'town', 'town_object', 'county', 'county_object', 'city', 'city_object', 'province', 'province_object']
for k in reversed(source_file_list):
data = codecs.open('json/%s.json' % k, 'r', 'utf-8').read()
js_data = 'let %s = ' % k + data + '\nexport {%s} ' % k
out_js = codecs.open('js/%s.js' % k, 'w', 'utf-8')
out_js.write(js_data)
json_data = json.loads(data)
mysql_data_list = []
if k == 'province':
for index, i in enumerate(json_data):
mysql_data = "INSERT INTO province ('_id', 'name', 'province_id') VALUES ('%s', '%s', '%s');\n" % (index + 1, i['name'], i['id']) # noqa
mysql_data_list.append(mysql_data)
if k == 'city':
index = 0
for province_id in sorted(json_data.keys()):
for city in json_data[province_id]:
index += 1
mysql_data = "INSERT INTO city ('_id', 'name', 'city_id', 'province_id') VALUES ('%s', '%s', '%s', '%s');\n" % (index, city['name'], city['id'], province_id) # noqa
mysql_data_list.append(mysql_data)
if k == 'county':
index = 0
for city_id in sorted(json_data.keys()):
for county in json_data[city_id]:
index += 1
mysql_data = "INSERT INTO county ('_id', 'name', 'county_id', 'city_id') VALUES ('%s', '%s', '%s', '%s');\n" % (index, county['name'], county['id'], city_id) # noqa
mysql_data_list.append(mysql_data)
if k == 'town':
index = 0
for county_id in sorted(json_data.keys()):
for town in json_data[county_id]:
index += 1
mysql_data = "INSERT INTO town ('_id', 'name', 'town_id', 'county_id') VALUES ('%s', '%s', '%s', '%s');\n" % (index, town['name'], town['id'], county_id) # noqa
mysql_data_list.append(mysql_data)
if k == 'village':
index = 0
for town_id in sorted(json_data.keys()):
for village in json_data[town_id]:
index += 1
mysql_data = "INSERT INTO village ('_id', 'name', 'village_id', 'town_id') VALUES ('%s', '%s', '%s', '%s');\n" % (index, village['name'], village['id'], town_id) # noqa
mysql_data_list.append(mysql_data)
if k in ['province', 'city', 'county', 'town', 'village']:
out_mysql = codecs.open('mysql/%s.sql' % k, 'w', 'utf-8')
index = 0
start = 0
while start < len(mysql_data_list):
end = start + 1000
out_mysql.write(''.join(mysql_data_list[start:end]))
start = end
out_mysql.close()
def pull_data():
province_object_json = json.loads(
codecs.open('json/province_object.json', 'r', 'utf-8').read())
city_json = json.loads(codecs.open('src/city.json', 'r', 'utf-8').read())
county_json = json.loads(codecs.open(
'src/county.json', 'r', 'utf-8').read())
town_json = json.loads(codecs.open('src/town.json', 'r', 'utf-8').read())
village_json = json.loads(codecs.open(
'src/village.json', 'r', 'utf-8').read())
special_city_json = json.loads(codecs.open(
'src/special_city.json', 'r', 'utf-8').read())
city_object_d = OrderedDict()
city_d = OrderedDict()
for c in city_json:
parent_id = c['id'][0:2] + '0000000000'
obj = {
"province": province_object_json[parent_id]['name'],
"name": c['name'],
"id": c['id']
}
city_object_d[c['id']] = obj
city_d.setdefault(parent_id, []).append(obj)
out_city_object = codecs.open('json/city_object.json', 'w', 'utf-8')
out_city = codecs.open('json/city.json', 'w', 'utf-8')
out_city_object.write(json.dumps(
city_object_d, ensure_ascii=False, indent=4))
out_city.write(json.dumps(city_d, ensure_ascii=False, indent=4))
county_object_d = OrderedDict()
county_d = OrderedDict()
special_city_object = OrderedDict()
for sc in special_city_json:
special_city_object[sc["id"]] = sc
for c in county_json:
parent_id = c['id'][0:4] + '00000000'
obj = {
"city": city_object_d[parent_id]['name'],
"name": c['name'],
"id": c['id']
}
county_object_d[c['id']] = obj
county_d.setdefault(parent_id, []).append(obj)
out_county_object = codecs.open('json/county_object.json', 'w', 'utf-8')
out_county = codecs.open('json/county.json', 'w', 'utf-8')
out_county_object.write(json.dumps(
county_object_d, ensure_ascii=False, indent=4))
out_county.write(json.dumps(county_d, ensure_ascii=False, indent=4))
town_object_d = OrderedDict()
town_d = OrderedDict()
for c in town_json:
parent_id = c['id'][0:6] + '000000'
# 特殊处理不带区的市
if parent_id in special_city_object:
obj = {
"city": city_object_d[parent_id]['name'],
"name": c['name'],
"id": c['id']
}
else:
obj = {
"city": county_object_d[parent_id]['name'],
"name": c['name'],
"id": c['id']
}
town_object_d[c['id']] = obj
town_d.setdefault(parent_id, []).append(obj)
out_town_object = codecs.open('json/town_object.json', 'w', 'utf-8')
out_town = codecs.open('json/town.json', 'w', 'utf-8')
out_town_object.write(json.dumps(
town_object_d, ensure_ascii=False, indent=4))
out_town.write(json.dumps(town_d, ensure_ascii=False, indent=4))
village_object_d = OrderedDict()
village_d = OrderedDict()
for c in village_json:
parent_id = c['id'][0:9] + '000'
obj = {
"city": town_object_d[parent_id]['name'],
"name": c['name'],
"id": c['id']
}
village_object_d[c['id']] = obj
village_d.setdefault(parent_id, []).append(obj)
out_village_object = codecs.open('json/village_object.json', 'w', 'utf-8')
out_village = codecs.open('json/village.json', 'w', 'utf-8')
out_village_object.write(json.dumps(
village_object_d, ensure_ascii=False, indent=4))
out_village.write(json.dumps(village_d, ensure_ascii=False, indent=4))
def main():
pull_data()
make_data()
if __name__ == '__main__':
main()
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/chinabian/provinces-and-cities-in-china.git
git@gitee.com:chinabian/provinces-and-cities-in-china.git
chinabian
provinces-and-cities-in-china
全国省市区
master

搜索帮助