Django中的Q对象

时间:2015-02-12 15:54:44

标签: python django django-queryset django-q

如何通过过滤器获得的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?),
    })

2 个答案:

答案 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,
    })

第二个选项,只需进行两次查询(两次过滤调用)。