Django @property用于.aggregate()

时间:2018-05-15 03:22:42

标签: python django python-3.x django-views

我正在尝试从模型中聚合整数列表。整数派生的字段是@property装饰器字段。装饰器按预期工作,并且在template.html内,如果直接传递,则显示没有问题。但是,如果我尝试将@property字段传递到.aggregate(),则传递给template的上下文会抛出一个错误,该错误基本上是Cannot resolve keyword 'sum_thing' into field.后跟一个模型字段列表不包括任何装饰者字段。

我的问题是 - 如何从模型中汇总(求和)派生字段?

#models.py

class Foo(models.Model):
    a = 10      # a & b are both
    b = 5       # models.IntegerField() items

    @property
    def sum_thing(self):
        return self.a - self.b

#views.py

class Bar(generic.ListView):

    def get_context_data(self, **kwargs):

        qs = Foo.object.all()

        totals = {}

        totals['sumthing'] = qs.aggregate(total=Sum('sum_thing')

        context = {
            'totals': totals
        }

        return context

**我大大简化了models.pyviews.py

1 个答案:

答案 0 :(得分:4)

您无法使用属性进行聚合,因为它不存在于db中。但是,您可以在Django的F表达式的帮助下对您的查询进行注释,以获取这些字段的实际值。请参阅下面的示例。

from django.db.models import F, Sum

Foo.objects.annotate(sum_a_and_b=F('a') + F('b')).aggregate(total=Sum('sum_a_and_b'))

你也可以做任何数学运算,如/ * + - 用F,你也可以这样做

.annotate(answer=F('a') + F('b') * 2)