我有一个CSV到JSON Python脚本,感谢用户Petri让我将Geonames CSV转换转换为MongoImport友好的JSON。
问题是,Geonames有一个名为alternatenames
的字段,当前被引用并视为一个长字符串。因此无法在MongoDB中正确查询。我想将字段更改为字符串数组,例如:"alternatenames":["name1", "name2"]
Python脚本如下所示:
import csv, simplejson, decimal, codecs
data = open("cities.txt")
reader = csv.DictReader(data, delimiter=",", quotechar='"')
with codecs.open("cities.json", "w", encoding="utf-8") as out:
for r in reader:
for k, v in r.items():
# make sure nulls are generated
if not v:
r[k] = None
# parse and generate decimal arrays
elif k == "loc":
r[k] = [decimal.Decimal(n) for n in v.strip("[]").split(",")]
# generate a number
elif k == "geonameid":
r[k] = int(v)
out.write(simplejson.dumps(r, ensure_ascii=False, use_decimal=True)+"\n")
我的CSV包含以下字段:
"geonameid","name","asciiname","alternatenames","loc","feature_class","feature_code","country_code","cc2","admin1_code","admin2_code","admin3_code","admin4_code"
3,"Zamīn Sūkhteh","Zamin Sukhteh","Zamin Sukhteh,Zamīn Sūkhteh","[48.91667,32.48333]","P","PPL","IR",,"15",,,
5,"Yekāhī","Yekahi","Yekahi,Yekāhī","[48.9,32.5]","P","PPL","IR",,"15",,,
7,"Tarvīḩ ‘Adāī","Tarvih `Adai","Tarvih `Adai,Tarvīḩ ‘Adāī","[48.2,32.1]","P","PPL","IR",,"15",,,
我当前的JSON输出如下所示:
{"loc": [48.91667, 32.48333], "name": "Zamīn Sūkhteh", "geonameid": 3, "feature_class": "P", "admin3_code": null, "admin2_code": null, "cc2": null, "feature_code": "PPL", "country_code": "IR", "admin1_code": "15", "alternatenames": "Zamin Sukhteh,Zamīn Sūkhteh", "asciiname": "Zamin Sukhteh", "admin4_code": null}
{"loc": [48.9, 32.5], "name": "Yekāhī", "geonameid": 5, "feature_class": "P", "admin3_code": null, "admin2_code": null, "cc2": null, "feature_code": "PPL", "country_code": "IR", "admin1_code": "15", "alternatenames": "Yekahi,Yekāhī", "asciiname": "Yekahi", "admin4_code": null}
{"loc": [48.2, 32.1], "name": "Tarvīḩ ‘Adāī", "geonameid": 7, "feature_class": "P", "admin3_code": null, "admin2_code": null, "cc2": null, "feature_code": "PPL", "country_code": "IR", "admin1_code": "15", "alternatenames": "Tarvih `Adai,Tarvīḩ ‘Adāī", "asciiname": "Tarvih `Adai", "admin4_code": null}
我想更改JSON输出以添加字符串数组,如下所示(向右滚动到alternatenames
):
{"loc": [48.91667, 32.48333], "name": "Zamīn Sūkhteh", "geonameid": 3, "feature_class": "P", "admin3_code": null, "admin2_code": null, "cc2": null, "feature_code": "PPL", "country_code": "IR", "admin1_code": "15", "alternatenames": ["Zamin Sukhteh", "Zamīn Sūkhteh"], "asciiname": "Zamin Sukhteh", "admin4_code": null}
{"loc": [48.9, 32.5], "name": "Yekāhī", "geonameid": 5, "feature_class": "P", "admin3_code": null, "admin2_code": null, "cc2": null, "feature_code": "PPL", "country_code": "IR", "admin1_code": "15", "alternatenames": ["Yekahi,Yekāhī"], "asciiname": "Yekahi", "admin4_code": null}
{"loc": [48.2, 32.1], "name": "Tarvīḩ ‘Adāī", "geonameid": 7, "feature_class": "P", "admin3_code": null, "admin2_code": null, "cc2": null, "feature_code": "PPL", "country_code": "IR", "admin1_code": "15", "alternatenames": ["Tarvih `Adai", "Tarvīḩ ‘Adāī"], "asciiname": "Tarvih `Adai", "admin4_code": null}
另外,我应该将Access 2010导出的CSV中的quotechar
更改为^
而不是"
,以避免双引号?
感谢您的帮助。
答案 0 :(得分:2)
将另一个“elif”添加到现有的“elif”中以处理“alternatenames”:
elif k == "alternatenames":
r[k] = [name.strip() for name in v.split(",")]
首先在逗号上拆分字符串,然后在开始/结束处去除空白。
答案 1 :(得分:0)
我认为你的quotechar不是问题所在。您必须手动指定希望将该字段转换为字符串列表。
警告:未经测试的代码如下
elif k == "alternatenames":
r[k] = unicode.split(v, ',')
我假设v是基于字符的unicode,但是如果它是ascii,请调整。
答案 2 :(得分:0)
尝试包含此内容:
elif k == "alternatenames":
r[k] = [v.split(",")]