5

所以我有一个处理测试结果的 Django 应用程序,我试图找到某个评估的中位数。我认为这会起作用:

e = Exam.objects.all()
total = e.count()
median = int(round(total / 2))
median_exam = Exam.objects.filter(assessment=assessment.id).order_by('score')[median:1]
median_score = median_exam.score

但它总是返回一个空列表。我可以得到我想要的结果:

e = Exam.objects.all()
total = e.count()
median = int(round(total / 2))
exams = Exam.objects.filter(assessment=assessment.id).order_by('score')
median_score = median_exam[median].score

我只是希望不必查询整套考试。我想写一个看起来像这样的原始 MySQL 查询:

SELECT score FROM assess_exam WHERE assessment_id = 5 ORDER BY score LIMIT 690,1

但如果可能的话,我想留在 Django 的 ORM 中。大多数情况下,我似乎无法将 order_by 与过滤器和限制一起使用,这让我很困扰。有任何想法吗?

4

1 回答 1

5

您的切片语法错误。冒号后面的值不是要获取的元素个数,而是切片结束的索引。正如您在第二个示例中所做的那样,在没有冒号的情况下单独使用“中位数”会起作用。

于 2010-06-15T17:50:43.200 回答