我在用python生成一个特定的JSON对象时遇到了一些困难。
我需要它采用以下格式:
[
{"id":0 , "attributeName_1":"value" , "attributeName_2":"value" , .... },
{"id":1 , "attributeName_2":"value" , "attributeName_3":"value" , .... },
.
.
.
]
我从2个对象中获取id,attributeNames和values。我尝试生成json如下:
data=[]
for feature in features_selected:
data.append({"id":feature.pk})
for attribute in attributes_selected:
if attribute.feature == feature:
data.append({attribute.attribute.name : attribute.value})
jsonData=json.dumps(data)
但我得到的结果并不是我想要的
[
{"id":0} , {"attributeName_1":"value"} , {"attributeName_2":"value"} ,
{"id":1} , {"attributeName_2":"value"} , {"attributeName_3":"value"} , .... },
.
.
.
]
2条答案
按热度按时间xxb16uws1#
问题在于,您在循环中多次追加到
data
:在内部循环中首先是{"id":feature.pk}
,然后是{attribute.attribute.name : attribute.value}
。相反,您需要在循环中定义一个字典,用
id
项和属性填充它,然后才追加:lvjbypge2#
对于那些到这里来寻找在循环中创建任意json的方法的人来说,这个问题类似于在循环中创建Python列表/字典,因为在Python中构建json的规范方法是构建相应的Python数据结构(list -〉json数组,dictionary -〉json对象)并使用
json.dump
(将其存储在json文件中)或json.dumps
(在内存中创建json字符串)将其序列化。OP中的情况可能是这样一种情况,其中解析使循环更直观并且更不容易出错。OP中的嵌套结构可以编写为嵌套在列表解析中的dict解析。其思想是使用内部迭代在每个外部迭代中构建字典。也可以合并两个字典。由于每个dict中需要一个
'id'
密钥,因此使用该密钥。类似的示例如下: