在Python中的循环中生成JSON

qij5mzcb  于 2023-02-07  发布在  Python
关注(0)|答案(2)|浏览(207)

我在用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"} , .... },
   .
   .
   .
]
xxb16uws

xxb16uws1#

问题在于,您在循环中多次追加到data:在内部循环中首先是{"id":feature.pk},然后是{attribute.attribute.name : attribute.value}
相反,您需要在循环中定义一个字典,用id项和属性填充它,然后才追加:

data=[]
for feature in features_selected:
    item = {"id": feature.pk}
    for attribute in attributes_selected:
        if attribute.feature == feature:
            item[attribute.attribute.name] = attribute.value
    data.append(item)

jsonData=json.dumps(data)
lvjbypge

lvjbypge2#

对于那些到这里来寻找在循环中创建任意json的方法的人来说,这个问题类似于在循环中创建Python列表/字典,因为在Python中构建json的规范方法是构建相应的Python数据结构(list -〉json数组,dictionary -〉json对象)并使用json.dump(将其存储在json文件中)或json.dumps(在内存中创建json字符串)将其序列化。
OP中的情况可能是这样一种情况,其中解析使循环更直观并且更不容易出错。OP中的嵌套结构可以编写为嵌套在列表解析中的dict解析。其思想是使用内部迭代在每个外部迭代中构建字典。也可以合并两个字典。由于每个dict中需要一个'id'密钥,因此使用该密钥。类似的示例如下:

data = [{'id': i+10, **{j: j // 2 for j in range(i, i+60) if j % 30 == 0}} for i in range(2)]

# convert to a json string
json_string = json.dumps(data)
# '[{"id": 10, "0": 0, "30": 15}, {"id": 11, "30": 15, "60": 30}]'

# or
# write to a json file
with open('myjson.json', 'w') as f:
    json.dump(data, f)

相关问题