Shell编程基础-06-awk命令入门

awk是一款报告生成器,更适合格式化文本,对文本进行较复杂格式处理,常用于提取信息
它拥有强大的文本格式化的能力,可以把"报告"理解为"报表"或者"表格",也就是说,我们可以利用awk命令,将一些文本整理成我们想要的样子,比如把一些文本整理成"表"的样子
grep 、sed、awk被称为linux中的"三剑客"。
grep 更适合单纯的查找或匹配文本
sed 更适合编辑匹配到的文本
awk 更适合格式化文本,对文本进行较复杂格式处理

一、标准语法
1、awk [options] ‘pattern{operation}’ FILE #筛选文件里的指定内容.,引号里边是正则操作

2、COMMAND | awk [options] ‘pattern{operation}’ #前面可以配合命令和管道符,来筛选前面命令结果的指定内容

二、常用操作
1、awk -F [+= -,] -v OFS=‘SEP’ #通过-F或者-v FS(两者效果等同)来指定后面的多个东西作为分隔符,-v OFS是指定输出分隔符,默认为空白字符,就是输出时带有前面的分隔符
案例:awk -F '[+-=]' -v OFS='_' '{print $1,$2,$3,$4}' test.log
a_b_c_d

2、awk -v FS=’#’ <=> awk -F ‘#’ 通过-F或者-v FS(两者效果等同)来指定后面的东西作为分隔符,输入分割符
案例:awk -F '[+-=]' '{print $1 $2 $3 $4}' test.log

3、jps|awk 'NR==1 {print $1}'使用NR来筛选具体的行,配合后面的print $n就可以取到某行某列的内容,也可以用//正则来筛选包含特定内容的行

三、其他
1、$0 表示显示整行 ,$NF表示当前行分割后的最后一列($0和$NF均为内置变量),wk可以灵活的将我们指定的字符与每一列进行拼接,或者把指定的字符当做一个新列插入到原来的列中,也可以通过{print} 或 {print $0}输出整行`
2、AWK 包含两种特殊的模式:BEGIN 和 END。
BEGIN模式表示,在处理指定的文本之前,需要先执行BEGIN模式中指定的动作,就像报表的表头
END模式表示,在处理完指定的文本之后,再执行END模式中指定的动作,就像报表的表尾

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值