首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Django,查询过滤从模型方法

Django,查询过滤从模型方法
EN

Stack Overflow用户
提问于 2010-02-17 06:14:24
回答 4查看 47.5K关注 0票数 71

我有这些模型:

代码语言:javascript
运行
复制
def Foo(Models.model):
    size = models.IntegerField()
    # other fields

    def is_active(self):
         if check_condition:
              return True
         else:
              return False

def Bar(Models.model):
     foo = models.ForeignKey("Foo")
     # other fields

现在,我想查询具有活动Foo的条形图:

代码语言:javascript
运行
复制
Bar.objects.filter(foo.is_active())

我得到的错误信息如下

代码语言:javascript
运行
复制
SyntaxError at /
('non-keyword arg after keyword arg'

我如何才能做到这一点?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2010-02-17 06:22:03

不能针对模型方法或属性进行查询。在查询中使用其中的条件,或者在Python中使用列表理解或genex进行过滤。

票数 39
EN

Stack Overflow用户

发布于 2014-01-26 20:00:32

您还可以使用自定义管理器。然后你可以运行下面这样的代码:

代码语言:javascript
运行
复制
Bar.objects.foo_active()

你要做的就是:

代码语言:javascript
运行
复制
class BarManager(models.Manager):
    def foo_active(self):
       # use your method to filter results
       return you_custom_queryset

查看docs

票数 32
EN

Stack Overflow用户

发布于 2010-02-17 06:24:30

您不能过滤方法,但是,如果Foo上的is_active方法检查Foo上的属性,则可以使用像Bar.objects.filter(foo__is_active_attribute=True)这样的双下划线语法

票数 10
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2276768

复制
相关文章

相似问题

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