awk 根据表格数据计算列中的值的中位数
示例
给定一个;用作列定界符的文件。我们使用以下为GNUawk编写的程序在第二列中计算值的中位数。提供的输入是学生组的成绩列表:
gawk -F';' '{ sample[NR] = $2 }
END {
asort(sample);
if(NR % 2 == 1) {
print(sample[int(NR/2) + 1])
} else {
print(sample[NR/2])
}
}' <<EOF
Alice;2
Victor;1
Barbara;1
Casper;4
Deborah;0
Ernest;1
Fabiola;4
Giuseppe;4
EOF该程序的输出为1。
请记住,它NR保存了要处理的行数,END因此在块中它保存了文件中的总行数。
awk的许多实现都没有对数组进行排序的功能,因此需要在使用上面的代码之前进行定义。
热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短