我已尝试过类似帖子的所有建议,但没有运气。我有一个项目列表,我用它来为字典列表创建值。该列表最终成为JSON对象,因此我无法在每个列表项周围添加单引号。
metrics = ["test_met_1","test_met_2","test_met_3","test_met_4","test_met_5"]
data = {
"reportDescription":{
"reportSuiteID":"some_suite",
"dateFrom":"yesterday",
"dateTo":"today",
"dateGranularity": "day",
"metrics":[]
}
}
if len(metrics) > 0:
for metric in metrics:
new_met = "{\"id\""+":"+"\""+metric+"\"}"
data["reportDescription"]["metrics"].append(new_met)
if len(elements) > 0:
for element in elements:
new_elm = "{\"id\""+":"+"\""+element+"\",\"top\""+":"+"\"50000\""+"}"
data["reportDescription"]["elements"].append(new_elm)
log_file = open('test.JSON','a')
log_file.write('\n\n'+str(datetime.now())+'\n'+str(data))
log_file.close()
我的结果:
{'reportDescription':'dateGranularity': 'day', 'dateTo': 'today', 'dateFrom': 'yesterday', 'metrics': ['{"id":"test_met_1"}', '{"id":"test_met_2"}', '{"id":"test_met_3"}', '{"id":"test_met_4"}', '{"id":"test_met_5"}'], 'reportSuiteID': 'some_suite'}
我真正需要的是:
{"reportDescription":"dateGranularity": "day", "dateTo": "today", "dateFrom": "yesterday", "metrics": [{"id":"test_met_1"}, {"id":"test_met_2"}, {"id":"test_met_3"}, {"id":"test_met_4"}, {"id":"test_met_5"}], "reportSuiteID": "some_suite"}
有关如何删除每个列表项周围的单引号的任何想法?我尝试了几种join()和/或replace()。虽然没有运气。
答案 0 :(得分:1)
如果要创建JSON字符串(或文件),请使用json
模块。
>>> data["reportDescription"]["metrics"] = [{"id": m} for m in metrics]
>>> json.dumps(data)
'{"reportDescription": {"metrics": [{"id": "test_met_1"}, {"id": "test_met_2"}, {"id": "test_met_3"}, {"id": "test_met_4"}, {"id": "test_met_5"}], "dateFrom": "yesterday", "dateGranularity": "day", "reportSuiteID": "some_suite", "dateTo": "today"}}'
要直接写入文件,请使用json.dump(data, log_file)
。 json
模块将负责正确转义字符串并使用正确的JSON引号等。
答案 1 :(得分:0)
获得结果字典后,使用json.dumps(yourdict)将其转换为json对象
别忘了导入json
确保你的字典很好。