如何使用 Django 检索模型字段的值分布?
How to retrieve a distribution of values for a models field using Django?
我有这样一个模型:
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')
经过一些更大胆的猜测并遵循 this 教程,我设法想出了这个解决方案:
Answer.objects.values('question','points_achieved')
.annotate(Count('points_achieved'))
我有这样一个模型:
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')
经过一些更大胆的猜测并遵循 this 教程,我设法想出了这个解决方案:
Answer.objects.values('question','points_achieved')
.annotate(Count('points_achieved'))