首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >django使用Q对象动态过滤

django使用Q对象动态过滤
EN

Stack Overflow用户
提问于 2012-10-26 04:34:29
回答 4查看 24.2K关注 0票数 40

我正在尝试根据用户输入标记来查询数据库。标签的数量可以从0到5,所以我需要动态创建查询。

所以我有一个标记列表,tag_list,并且我想查询数据库:

代码语言:javascript
复制
design_list = Design.objects.filter(Q(tags__tag__contains = "tag1") and Q(tags__tag__contains = "tag2") and etc. etc. )

如何创建此功能?

EN

回答 4

Stack Overflow用户

发布于 2018-06-09 22:43:45

您可以这样使用:

代码语言:javascript
复制
my_dict = {'field_1': 1, 'field_2': 2, 'field_3': 3, ...}  # Your dict with fields
or_condition = Q()
for key, value in my_dict.items():
    or_condition.add(Q(**{key: value}), Q.OR)

query_set = MyModel.objects.filter(or_condition)

通过这种方式,您可以使用动态生成的字段名。对于AND条件,您也可以使用Q.AND

票数 26
EN

Stack Overflow用户

发布于 2012-10-26 04:41:19

只需先准备一个标签列表,然后像这样查询:

代码语言:javascript
复制
tags = ['tag1', 'tag2',...]
design_list = Design.objects.filter(tags__tag__contains__in = tags)
票数 3
EN

Stack Overflow用户

发布于 2020-07-29 22:34:22

您可能需要添加AND和OR条件

代码语言:javascript
复制
    query = (Q(fild1='ENABLE'))
    # Filter by list
    query.add(Q(fild2__in=[p.code for p in Objects.field.all()]), Q.AND)

    # filter OR
    q_objects = Q(field3='9999999')
    for x in myList:
        q_objects.add(Q(field3=x.code), Q.OR)

    query.add(q_objects, Q.AND)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13076822

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档