兽性大发腐书网,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离职了,希望能过得开心.
如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复
新手学习Python2和Python3中print不同的用法
Python基于os.environ从windows获取环境变量
网友评论