如何将值附加到python列表而不是用最新值

时间:2016-07-10 03:10:01

标签: python django dictionary

以下是我的python / django代码:

values = Record.objects.filter(record_id__in=[1,2,3], is_main_record=True)
if values .filter(status='open'):
   all_item = ['sasi', 'kuttu','vava']
   for item in items:
        values1 = values.filter(set=mask, status='open')
        print values1

上面的代码会给我每个项目中的对象。现在我想创建一个字典,以便我可以创建如下的数据结构:

jobs = [
        {'item': 'A', 'device': 'deviceA', 'log': 'logA'},
        {'item': 'A', 'device': 'device1', 'log': 'ptrf1'},
        {'item': 'B', 'device': 'deviceb', 'log': 'ptrfb'},
        {'item': 'C', 'device': 'devicec', 'log': 'ptrfc'},
    ]

为此,我添加了:

 jobs = []
 values = Record.objects.filter(record_id__in=[1,2,3], is_main_record=True)
    if values .filter(status='open'):
       all_item = ['sasi', 'kuttu','vava']
       for mask in all_item:
            values1 = values.filter(set=mask, status='open')
            for x in values1:
                data = {'item' : x.item, 'device':x.device, 'log':x.log}
                jobs.append(data)
            print jobs

但是工作总是给我最新的项目,而不是我上面提到的数据结构(每个项目的列表)。如何解决这个问题并实现我提到的数据结构?对不起Python和编码新手。如果我问任何愚蠢的问题,请原谅。先谢谢你们。

1 个答案:

答案 0 :(得分:1)

jobs = []
values = Record.objects.filter(record_id__in=[1,2,3], is_main_record=True, status='open', set__in=['sasi', 'kuttu','vava'])
if values.exists():
   all_item = ['sasi', 'kuttu','vava']
   for mask in all_item:
       for x in values:
           data = {'item' : x.item, 'device': x.device, 'log': x.log}
           jobs.append(data)

print jobs # <--- print here, then you see the whole list

你的代码很好,你只是在一个循环步骤中打印,它只给你动量值而不是整个列表

我更新了查询,从而减少了数据库查询次数。