当前位置: 移动技术网 > IT编程>脚本编程>Python > 【Django】对符合条件的某个字段进行求和,聚合函数annotate()

【Django】对符合条件的某个字段进行求和,聚合函数annotate()

2018年07月04日  | 移动技术网IT编程  | 我要评论

兽性大发腐书网,dsa,桓仁贴吧

对符合条件的某个字段求和

  之前在开发的时候,有同事问Django是否存在着这样的方法,可以直接将符合条件的某个字段直接求和.

  当时不知道这样的方法是否存在,但是想了想自己解决这类似问题的方法,先用filter将符合条件的取出来,然后进行for循环,取出需要的字段,进行求和.感觉是挺low的,于是一起Baidu,写代码测试最后找到了可以求值的方法,聚合函数annotate().

from django.db.models import Sum
from models import Book
all_price = Book.objects.values('price').annotate(num_books=Sum('price')).filter(author='Yu')
print all_price[0]['num_books'] 输出结果:650

上面的参数换个顺序,不会出错但不符合预期结果.

all_price = Book.objects.annotate(num_books=Sum('price')).filter(author='Yu').values('price')
print all_youxibi[0]['num_books']
输出结果:'nums_book'

 

 

该同事昨天也就是2018-07-03离职了,希望能过得开心.

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网