bash – 列的中位数与awk

如何使用AWK来计算一列数值数据的中位数?

我可以想到一个简单的算法,但我似乎无法编程:

我到目前为止是:

sort | awk 'END{print NR}'

这给了我列中的元素数量.我想用这个来打印某个行(NR / 2).如果NR / 2不是整数,那么我舍入到最接近的整数,即中值,否则我取平均值(NR / 2)1和(NR / 2)-1.

这个awk程序假设有一列数字排序的数据:
#/usr/bin/env awk
{
    count[NR] = $1;
}
END {
    if (NR % 2) {
        print count[(NR + 1) / 2];
    } else {
        print (count[(NR / 2)] + count[(NR / 2) + 1]) / 2.0;
    }
}

使用样例

sort -n data_file | awk -f median.awk

相关文章

用的openwrt路由器,家里宽带申请了动态公网ip,为了方便把2...
#!/bin/bashcommand1&command2&wait从Shell脚本并行...
1.先查出MAMP下面集成的PHP版本cd/Applications/MAMP/bin/ph...
1、先输入locale-a,查看一下现在已安装的语言2、若不存在如...
BashPerlTclsyntaxdiff1.进制数表示Languagebinaryoctalhexa...
正常安装了k8s后,使用kubect工具后接的命令不能直接tab补全...