语法
awk '条件1 {动作1} 条件2 {动作2} ...' 文件名
如果条件1符合,执行动作1,如果条件2符合,执行动作2
条件:
一般使用关系表达式作为条件
x > 10 判断变量x是否大于10
x >= 10 大于等于
x <= 10 小于等于
动作:
格式化输出
流程控制语句
注意:之所以使用awk截取命令,主要是cut不能截取以" "或者tab作为分隔符的字符串,而awk默认的分隔符就是这两个
实例
输出第2列和第6列
截取sda5的第五列的磁盘占用百分数
其中cut是以"%"分割"12%",然后取第一个字段
BEGIN,在所有的数据读取之前执行BEGIN后的动作,然后再处理后面的数据
FS内置变量:指定分割符":"
由于awk先读取第一行,再从第二行开始处理,因此第一行没有分割
解决办法,在FS前加入BEGIN,在读取第一条数据之前,先把分隔符指定,再进行处理
END,在所有的数据执行完之后,再执行一个动作
关系运算符
选取成绩大于87的学生的名字,不包含Name所在的行,用grep -v反选Name所在的行,否则awk先会读取第一行的内容,再处理后面的数据