42

ユーザー入力タグに基づいてデータベースにクエリを実行しようとしています。タグの数は0〜5の範囲である可能性があるため、クエリを動的に作成する必要があります。

したがって、タグリストtag_listがあり、データベースにクエリを実行したいと思います。

design_list = Design.objects.filter(Q(tags__tag__contains = "tag1") and Q(tags__tag__contains = "tag2") and etc. etc. )

この機能を作成するにはどうすればよいですか?

4

5 に答える 5

104

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:最初のアイデアについては、Freenodeの#djangoのkezabelleにクレジットしてください。

于 2012-10-25T20:40:45.910 に答える
27

次のように使用できます。

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

于 2018-06-09T14:43:44.793 に答える
3

最初にタグリストを準備してから、次のようにクエリを実行します。

tags = ['tag1', 'tag2',...]
design_list = Design.objects.filter(tags__tag__contains__in = tags)
于 2012-10-25T20:41:19.067 に答える
1

ANDおよびOR条件を追加する必要がある場合があります

    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)
于 2020-07-29T14:34:22.153 に答える
1

使用するreduce:

from functools import reduce
design_list = Design.objects.filter(reduce(lambda q1,q2: q1 & q2,
                                           [Q(tags__tag__contains=t)
                                            for t in tag_list]))
于 2021-03-02T16:31:39.540 に答える