首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Django中缺少'Median‘聚合函数?

Django中缺少'Median‘聚合函数?
EN

Stack Overflow用户
提问于 2009-06-03 00:51:25
回答 6查看 6.7K关注 0票数 12

Django的开发版本具有诸如平均值、计数、最大值、最小值、StdDev、总和和方差(link text)等聚合函数。列表中缺少Median是有原因的吗?

实现一个看起来很简单。我是不是遗漏了什么?聚合函数在幕后做了多少工作?

EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2009-06-03 03:27:26

因为median不是SQL聚合。例如,请参见list of PostgreSQL aggregate functionsthe list of MySQL aggregate functions

票数 15
EN

Stack Overflow用户

发布于 2012-03-01 00:56:06

这是您缺少的函数。向它传递一个查询集和要计算其中值的列的名称:

代码语言:javascript
复制
def median_value(queryset, term):
    count = queryset.count()
    return queryset.values_list(term, flat=True).order_by(term)[int(round(count/2))]

这并不像其他一些回应所显示的那样困难。重要的是让db排序来做所有的工作,所以如果你已经对列进行了索引,这是一个非常便宜的操作。

(2016年1月28日更新)如果您想更严格地定义偶数个项目的中位数,这将对两个中间值的值进行平均。

代码语言:javascript
复制
def median_value(queryset, term):
    count = queryset.count()
    values = queryset.values_list(term, flat=True).order_by(term)
    if count % 2 == 1:
        return values[int(round(count/2))]
    else:
        return sum(values[count/2-1:count/2+1])/Decimal(2.0)
票数 24
EN

Stack Overflow用户

发布于 2009-06-03 00:57:17

好吧,原因可能是你需要跟踪所有的数字来计算中位数。Avg、Count、Max、Min、StDev、Sum和Variance都可以在存储需求不变的情况下进行计算。也就是说,一旦你“记录”了一个数字,你就再也不需要它了。

FWIW,你需要跟踪的变量是: min,max,count,<n> = avg,<n^2> =值的平方。

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/942620

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档