如何通过过滤器获得的var值来选择然后在循环中附加值?
items = Item.objects.filter(Q(var__icontains=term) | Q(another_var__icontains=term))
res = []
for item in items:
res.append({
'val': item.(var or another_var?),
})
答案 0 :(得分:0)
我担心您必须手动检查var
/ anohter_var
以查找查询集中匹配的变量。
items = Item.objects.filter(Q(var__icontains=term) |
Q(another_var__icontains=term))
uterm = term.upper()
res = []
for item in items:
value = item.var if uterm in item.var.upper() else item.another_var
res.append({'val': value})
答案 1 :(得分:0)
在本地检查,或者执行两个不同的查询。 第一种选择:
items = Item.objects.filter(Q(var__icontains=term) | Q(another_var__icontains=term))
res = []
for item in items:
if term.lower() in item.var.lower():
v = item.var
else:
v = item.another_var
res.append({
'val': v,
})
第二个选项,只需进行两次查询(两次过滤调用)。