以下是我的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和编码新手。如果我问任何愚蠢的问题,请原谅。先谢谢你们。
答案 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
你的代码很好,你只是在一个循环步骤中打印,它只给你动量值而不是整个列表
我更新了查询,从而减少了数据库查询次数。