我想将元组列表转换为 json,但我的代码有问题,因为我没有得到我所期望的结果。
我知道这个问题已经被问过,但是通过更简单的输入,我无法让它与我的一起工作。
Input list
result = [('a', 'company', '2', 2, 'myError'),
('c', 'company', '5', 7, 'myError'),
('b', 'tax', '23', 1, 'myError')]
这是代码:我迭代列表 result
并解开其中的元组并连接元组 e
。
e = ()
for element in result:
e = e + ((element[1],
(('uuid', str(element[0])),
('id', element[2]),
('error_id', element[3]),
('error_msg', element[4]))),)
logging.info(json.dumps(dict(e)))
Actual result
{
"company": [
["id", "a"],
["row", "2"],
["err", 2],
["msg", "myError"]
],
"tax": [
["id", "b"],
["row", "23"],
["err", 1],
["msg", "myError"]
]
}
expected result
{
"company": [
{
"id": "a",
"row": "2",
"err": 2,
"msg": "myError"
},
{
"id": "c",
"row": "5",
"err": 7,
"msg": "myError"
}
],
"tax": [
{
"id": "b",
"row": "23",
"err": 1,
"msg": "myError"
}
]
}
如何获取正确的json?
最佳答案
from collections import defaultdict
e = defaultdict(list)
for element in result:
e[element[1]].append({'uuid': str(element[0]), 'id': element[2],
'error_id': element[3], 'error_msg': element[4]})
dict(e)
将为您提供所需格式的字典。
关于python - 如何将 python 元组列表转换为 json,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36474742/