gpt4 book ai didi

python - 如何使用 Django 检索模型字段的值分布?

转载 作者:行者123 更新时间:2023-11-30 23:13:35 24 4
gpt4 key购买 nike

我有一个这样的模型:

class Question(models.Model):
#something

class Answer(models.Model):
question = models.ForeignKey(Question)
points_achieved = models.PositiveSmallIntegerField()

现在我想查询points_achieved的分布:对于每个问题我想知道有多少人得分为0分,1分等。在 python 中,我将按如下方式执行此操作:

dists = []
for q in Question.objects.all():
dist = defaultdict(int)
for answer in q.answer_set.all():
dist[answer.points_achieved]+=1
dists.append(dist)

如何使用 Django 的查询方法完成相同的任务?

最佳答案

试试这个

from django.db.models import Count
Answer.objects.all().values('question', 'points_achieved').annotate(total=Count('points_achieved')).order_by('total')

来源:Django Aggregation

关于python - 如何使用 Django 检索模型字段的值分布?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29243716/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com