首页 > 技术文章 > awk命令

my_captain 2018-12-07 18:31 原文

语法

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先会读取第一行的内容,再处理后面的数据

 

推荐阅读