0
点赞
收藏
分享

微信扫一扫

awk命令

语法

awk '条件1 {动作1} 条件2 {动作2} ...' 文件名

如果条件1符合,执行动作1,如果条件2符合,执行动作2

条件:

  一般使用关系表达式作为条件

  x > 10    判断变量x是否大于10

  x >= 10     大于等于

  x <= 10     小于等于

动作:

  格式化输出

  流程控制语句

注意:之所以使用awk截取命令,主要是cut不能截取以" "或者tab作为分隔符的字符串,而awk默认的分隔符就是这两个

awk命令_数据

实例

输出第2列和第6列

awk命令_格式化输出_02

截取sda5的第五列的磁盘占用百分数

其中cut是以"%"分割"12%",然后取第一个字段

awk命令_格式化输出_03

BEGIN,在所有的数据读取之前执行BEGIN后的动作,然后再处理后面的数据

awk命令_分隔符_04

FS内置变量:指定分割符":"

由于awk先读取第一行,再从第二行开始处理,因此第一行没有分割

awk命令_分隔符_05

解决办法,在FS前加入BEGIN,在读取第一条数据之前,先把分隔符指定,再进行处理

awk命令_数据_06

END,在所有的数据执行完之后,再执行一个动作

awk命令_格式化输出_07

awk命令_分隔符_08

关系运算符

选取成绩大于87的学生的名字,不包含Name所在的行,用grep -v反选Name所在的行,否则awk先会读取第一行的内容,再处理后面的数据

awk命令_格式化输出_09

 


举报

相关推荐

0 条评论