我想根据用户输入的标签来查询数据库。 标签的数量可以是0-5,所以我需要动态地创建查询。
所以我有一个标签列表,tag_list,我想查询数据库:
design_list = Design.objects.filter(Q(tags__tag__contains = "tag1") and Q(tags__tag__contains = "tag2") and etc. etc. )
如何创建这个功能吗?
我想根据用户输入的标签来查询数据库。 标签的数量可以是0-5,所以我需要动态地创建查询。
所以我有一个标签列表,tag_list,我想查询数据库:
design_list = Design.objects.filter(Q(tags__tag__contains = "tag1") and Q(tags__tag__contains = "tag2") and etc. etc. )
如何创建这个功能吗?
您可以通过tag_list要循环和应用过滤器的每一个。
tag_list = ['tag1', 'tag2', 'tag3']
base_qs = Design.objects.all()
for t in tag_list:
base_qs = base_qs.filter(tags__tag__contains=t)
这会给你的结果匹配所有的标签,因为你的榜样与指示and
。 如果事实上你需要or
相反,你可能会需要Q对象。
编辑:我想我知道你在找什么了。
tags = ['tag1', 'tag2', 'tag3']
q_objects = Q() # Create an empty Q object to start with
for t in tags:
q_objects |= Q(tags__tag__contains=t) # 'or' the Q objects together
designs = Design.objects.filter(q_objects)
我测试了这一点,它似乎工作得很好。
编辑2:感谢在#django kezabelle Freenode上了最初的想法。
你可以用这种方式:
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)
通过这种方式,您可以使用动态生成的字段名。 你也可以使用Q.AND
为AND
条件。
只需要准备一个标签列表第一的话,这样的查询:
tags = ['tag1', 'tag2',...]
design_list = Design.objects.filter(tags__tag__contains__in = tags)