[root@gaojingbo Desktop]# awk 'BEGIN{printf "姓名\t语文\t数学\t物理\t化学\t英语\t生物\t\n " ;OFS="\t"}{print $1,$2,$3,$4,$5,$6,$7}END{print "学生成绩"}' student.txt
或者
[root@gaojingbo ~]# cat /root/Desktop/student.txt |awk 'BEGIN{printf "姓名\t\t语文\t数学\t物理\t化学\t英语\t生物\t\n"}{printf "%-20s\n" ,$0}END{printf "学生成绩\n"}'
姓名 语文 数学 物理 化学 英语 生物
mona 70 77 85 83 70 89
john 85 92 78 94 88 91
andrea 89 90 85 94 90 95
jasper 84 88 80 92 84 82
dunce 6 80 60 60 61 62
ellis 5 98 89 96 96 92
学生成绩
将上午所做的打印各个人的成绩的作业,继续算出两个字段,每个人的总分和每个人的平均分
[root@gaojingbo Desktop]# awk 'BEGIN{printf "姓名\t语文\t数学\t物理\t化学\t英语\t生物\t总分\t平均分\t\n " ;OFS="\t"}{print $1,$2,$3,$4,$5,$6,$7,$2+$3+$4+$5+$6+$7,($2+$3+$4+$5+$6+$7)/6}END{print "学生成绩"}' student.txt
姓名 语文 数学 物理 化学 英语 生物 总分 平均分
mona 70 77 85 83 70 89 474 79
john 85 92 78 94 88 91 528 88
andrea 89 90 85 94 90 95 543 90.5
jasper 84 88 80 92 84 82 510 85
dunce 6 80 60 60 61 62 329 54.8333
ellis 5 98 89 96 96 92 476 79.3333
学生成绩
在上次的输出结果的基础上打印出90分以上的为A,60-90之间的为B,60分以下的C
[root@gaojingbo Desktop]# awk 'BEGIN{printf "姓名\t语文\t数学\t物理\t化学\t英语\t生物\t总分\t平均分\t\n " ;OFS="\t"}{print $1,$2,$3,$4,$5,$6,$7,$2+$3+$4+$5+$6+$7,($2+$3+$4+$5+$6+$7)/6}{if(($2+$3+$4+$5+$6+$7)/6>=60) {print "A"}else if (($2+$3+$4+$5+$6+$7)/6<60){print "C"}else {print "B"}}END{print "学生成绩"}' student.txt
姓名 语文 数学 物理 化学 英语 生物 总分 平均分
mona 70 77 85 83 70 89 474 79
A
john 85 92 78 94 88 91 528 88
A
andrea 89 90 85 94 90 95 543 90.5
A
jasper 84 88 80 92 84 82 510 85
A
dunce 6 80 60 60 61 62 329 54.8333
C
ellis 5 98 89 96 96 92 476 79.3333
A
学生成绩
统计每个学生的平均分在90分以上的,60-90的,60分以下分别有多少个?
先在student.txt文件中加入平均分成绩再使用awk
[root@gaojingbo Desktop]# awk '{if($8>=90){i++} else if($8<=60){k++} else{j++}} END{print "90分以上学生个数: "i; print "60分以下学生个数: "k; print "60分-80分学生个数: "j}' student.txt
90分以上学生个数: 1
60分以下学生个数: 1
60分-80分学生个数: 4
统计/etc/passwd 文件里面不同的shell类型的个数
[root@gaojingbo Desktop]# awk -F: '{shell[$NF]++} END{for(i in shell){print i,shell[i]}}' /etc/passwd
/bin/sync 1
/bin/bash 20
/sbin/nologin 44
/sbin/halt 1
/sbin/shutdown 1