python - Django 中缺少 'Median' 聚合函数?

标签 python django aggregate-functions

Django 的开发版具有聚合函数,例如 Avg、Count、Max、Min、StdDev、Sum 和 Variance (link text)。列表中缺少 Median 是否有原因?

实现一个似乎很容易。我错过了什么吗?聚合函数在幕后做了多少?

最佳答案

这是您缺少的功能。向它传递一个查询集和要为其查找中位数的列的名称:

def median_value(queryset, term):
    count = queryset.count()
    return queryset.values_list(term, flat=True).order_by(term)[int(round(count/2))]

这并不像其他一些回复所表明的那么难。重要的是让数据库排序完成所有工作,因此如果您已经为列编制了索引,这是一个 super 便宜的操作。

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

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)

关于python - Django 中缺少 'Median' 聚合函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/942620/

相关文章:

python - 带有 pymc 的蒙特卡罗马尔可夫链

python - Pyspark - 调用 pandas_udf 时出错,返回 Series.interpolate() 作为结果

django - 从 ManyToMany 查询集中序列化数据

django - ubuntu18.04中无法通过url连接mongodb

python - 访问 Pandas 专栏的最快方法

python - 在 TestCase 执行期间 django.db.connection.cursor() SQL 查询从主数据库返回数据,而不是从测试数据库返回数据

sql - Oracle - 在聚合函数中使用分析函数

hadoop - hive 中的第一个()

mysql 为选定的行数生成每列的总和

python - 将行解析为单独的段 - python