shell脚本编程学习第十一天
K、teamlist.txt的内容为:
Name,Team,First Test, Second Test, Third Test
Tom,Red,5,17,22
Joe,Green,3,14,22
Maria,Blue,6,18,21
Fred,Blue,2,15,23
Carlos,Red,-1,15,24
Phuong,Green,7,19,21
Enrique,Green,3,16,20
Nancy,Red,9,12,24
编写一个awk脚本用来计算每个人的平均成绩,每次测试的平均成绩和每组队的平均成绩。如果某次成绩为负数,则表示此人错过了测试,那计算平均成绩时排除此人再计算。
输出的结果如下表,在名字的列表中,名字是10个宽度且左对齐(提示printf中使用%-10s格式),而平均值是7个字符宽度,右边两个右对齐的小数。
#!/bin/bash
awk -F, ' // 再次强调,这个单引号千万别另起一行
BEGIN{
printf "%-10s %s\n","Name","Average"
printf "%-10s %s\n","----","-------"
}
NR>1{ // statements2里,写起来就按照习惯正常写就行
sum=0
n=0
for (i=3;i<=5;i++){
if ($i>0) {
sum+=$i
n++
testcount[i-2]++
testtotal[i-2]+=$i
teamcount[$2]++
teamtotal[$2]+=$i
}
}
printf "%-10s %7.2f\n",$1,sum/n
}
END{
print "------------------"
for (j=1;j<=3;j++){
print "Average for Test "j" : "testtotal[j]/testcount[j]
}
print "-------------------"
for (t in teamcount){
print "Average for "t" Team: "teamtotal[t]/teamcount[t]
} // 数好大括号配对情况
}' teamlist.txt