120

例から、複数の OR クエリ フィルターを確認できます。

Article.objects.filter(Q(pk=1) | Q(pk=2) | Q(pk=3))

たとえば、次のようになります。

[<Article: Hello>, <Article: Goodbye>, <Article: Hello and goodbye>]

ただし、リストからこのクエリ フィルターを作成したいと考えています。どうやってするか?

例えば[1, 2, 3] -> Article.objects.filter(Q(pk=1) | Q(pk=2) | Q(pk=3))

4

14 に答える 14

184

次のようにクエリを連鎖させることができます。

values = [1,2,3]

# Turn list of values into list of Q objects
queries = [Q(pk=value) for value in values]

# Take one Q object from the list
query = queries.pop()

# Or the Q object with the ones remaining in the list
for item in queries:
    query |= item

# Query the model
Article.objects.filter(query)
于 2009-05-12T12:21:28.030 に答える
90

より複雑なクエリを作成するには、次のように、組み込みの Q() オブジェクトの定数 Q.OR および Q.AND を add() メソッドと一緒に使用するオプションもあります。

list = [1, 2, 3]
# it gets a bit more complicated if we want to dynamically build
# OR queries with dynamic/unknown db field keys, let's say with a list
# of db fields that can change like the following
# list_with_strings = ['dbfield1', 'dbfield2', 'dbfield3']

# init our q objects variable to use .add() on it
q_objects = Q(id__in=[])

# loop trough the list and create an OR condition for each item
for item in list:
    q_objects.add(Q(pk=item), Q.OR)
    # for our list_with_strings we can do the following
    # q_objects.add(Q(**{item: 1}), Q.OR)

queryset = Article.objects.filter(q_objects)

# sometimes the following is helpful for debugging (returns the SQL statement)
# print queryset.query
于 2015-03-19T16:26:07.727 に答える
47

python の reduce 関数を使用して Dave Webb の回答を短く書く方法:

# For Python 3 only
from functools import reduce

values = [1,2,3]

# Turn list of values into one big Q objects  
query = reduce(lambda q,value: q|Q(pk=value), values, Q())  

# Query the model  
Article.objects.filter(query)  
于 2009-05-22T13:36:12.713 に答える
43
from functools import reduce
from operator import or_
from django.db.models import Q

values = [1, 2, 3]
query = reduce(or_, (Q(pk=x) for x in values))
于 2009-05-22T14:34:19.337 に答える
23

たぶん、SQL IN ステートメントを使用する方が良いでしょう。

Article.objects.filter(id__in=[1, 2, 3])

クエリセット API リファレンスを参照してください。

動的ロジックを使用してクエリを作成する必要がある場合は、次のようにすることができます (醜い + テストされていません)。

query = Q(field=1)
for cond in (2, 3):
    query = query | Q(field=cond)
Article.objects.filter(query)
于 2009-05-12T12:12:40.350 に答える
10

ドキュメントを参照してください:

>>> Blog.objects.in_bulk([1])
{1: <Blog: Beatles Blog>}
>>> Blog.objects.in_bulk([1, 2])
{1: <Blog: Beatles Blog>, 2: <Blog: Cheddar Talk>}
>>> Blog.objects.in_bulk([])
{}

この方法は主キーのルックアップに対してのみ機能することに注意してください。

だからあなたが欲しいのは:

Article.objects.in_bulk([1, 2, 3])
于 2009-05-12T12:11:18.750 に答える
8

reduceおよびor_演算子を使用して乗算フィールドでフィルタリングする ソリューション。

from functools import reduce
from operator import or_
from django.db.models import Q

filters = {'field1': [1, 2], 'field2': ['value', 'other_value']}

qs = Article.objects.filter(
   reduce(or_, (Q(**{f'{k}__in': v}) for k, v in filters.items()))
)

psfは新しいフォーマット文字列リテラルです。Python 3.6で導入されました

于 2017-12-04T12:20:36.520 に答える
7

照会したい db フィールドをプログラムで設定したい場合:

import operator
questions = [('question__contains', 'test'), ('question__gt', 23 )]
q_list = [Q(x) for x in questions]
Poll.objects.filter(reduce(operator.or_, q_list))
于 2012-09-24T16:01:10.333 に答える
4

|= 演算子を使用して、Q オブジェクトを使用してクエリをプログラムで更新できます。

于 2009-05-12T12:12:30.603 に答える
2

これは動的 pk リスト用です。

pk_list = qs.values_list('pk', flat=True)  # i.e [] or [1, 2, 3]

if len(pk_list) == 0:
    Article.objects.none()

else:
    q = None
    for pk in pk_list:
        if q is None:
            q = Q(pk=pk)
        else:
            q = q | Q(pk=pk)

    Article.objects.filter(q)
于 2014-08-02T10:30:20.723 に答える
0

簡単..
from django.db.models import Q import you model args = (Q(visibility=1)|(Q(visibility=0)&Q(user=self.user))) #Tuple parameters={} #dic order = 'create_at' 制限 = 10

Models.objects.filter(*args,**parameters).order_by(order)[:limit]
于 2015-12-18T15:50:12.393 に答える