您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

python – 使用dict参数的带有OR条件的Django过滤器

5b51 2022/1/14 8:22:35 python 字数 2519 阅读 546 来源 www.jb51.cc/python

我在我的Django应用程序上有一个函数,我执行一些Queryset操作并将其结果设置为Memcache.由于它是一种功能,因此必须具有一般用途.因此,为了使其可重用,我将dict作为过滤和排除操作的参数传递.这是功能: def cached_query(key, model, my_filter=None, exclude=None, order_by=None, sliced=50):

概述

def cached_query(key,model,my_filter=None,exclude=None,order_by=None,sliced=50):
    """
    :param key: string used as key reference to store on Memcached
    :param model: model reference on which 'filter' will be called
    :param my_filter: dictionary containing the filter parameters (eg.: {'title': 'foo','category': 'bar'}
    :param sliced: integer limit of results from the query. The lower the better,since for some reason Django Memcached
        won't store thousands of entries in memory
    :param exclude: dictionary containing the exclude parameters (eg.: {'title': 'foo','category': 'bar'}
    :param order_by: tuple containing the list of fields upon which the model will be ordered.
    :return: list of models. Not a QuerySet,since it was sliced.
    """
    result = cache.get(key,None)
    if not result:
        if my_filter:
            result = model.objects.filter(**my_filter)
        if exclude:
            result = result.exclude(**exclude)
        if order_by:
            result = result.order_by(*order_by)
        else:
            result = model.objects.all()
        result = result[:sliced]
        cache.set(key,result,cache_timeout)
    return result

如果我使用像”title’:’foo’,’name’:’bar’}这样的简单字典过滤查询集,它的工作方式非常好.然而,并非总是如此.我需要使用django.db.models.Q实用程序对需要OR条件的更复杂查询执行过滤器.

那么,我如何将这些参数作为字典传递给过滤器.这有什么办法吗?

from functools import reduce
import operator

from django.db.models import Q

# your dict is my_filter
q = model.objects.filter(reduce(operator.or_,(Q(**d) for d in [dict([i]) for i in my_filter.items()])))

减少or_连接OR上的Q表达式.

您还可以使用生成器表达式,其中包含dicts列表:

q = model.objects.filter(reduce(operator.or_,(Q(**d) for d in (dict([i]) for i in my_filter.items()))))

总结

以上是编程之家为你收集整理的python – 使用dict参数的带有OR条件的Django过滤器全部内容,希望文章能够帮你解决python – 使用dict参数的带有OR条件的Django过滤器所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶