Shell学习(五)—— awk命令详解
作者:互联网
一、awk简介
awk是一个非常好用的数据处理工具,相对于sed常常作用于一整个行的处理,awk则比较倾向于一行当中分成数个【字段】处理,因此,awk相当适合处理小型的数据数据处理。awk是一种报表生成器,就是对文件进行格式化处理的,这里的格式化不是文件系统的格式化,而是对文件内容进行各种“排版”,进而格式化显示;在linux中我们使用的是GNU awk简称gawk,并且gawk其实就是awk的链接文件,因此在系统上使用awk和gawk是一样的。
二、awk语法
语法格式:
awk [-F|-f|-v] ‘BEGIN{} //{command1; command2} END{}’ file[,file2,...,filen]
选项:
[-F|-f|-v] 大参数,-F指定分隔符,-f调用脚本,-v定义变量 var=value
' ' 引用代码块
BEGIN 这里面放的是执行前的语句。初始化代码块,主要是引用全局变量,设置FS分隔符。
// 匹配代码块,可以是字符串或正则表达式
{} 这里面放的是处理每一行时要执行的语句。命令代码块,包含一条或多条命令,多条命令使用分号分隔
END 这里面放的是处理完所有的行后要执行的语句。结尾代码块,主要是进行最终计算或输出结尾摘要信息
举例:
cat ceshi.txt |awk -v FS: '{print $1,$3}'(每行按冒号分割,输出第一个域和第三个域;默认为空格分割;注意:awk后续动作都要以单引号引起来)
cat ceshi.txt |awk -v FS: '{print $1"XXXX"$3}'("XXXX"代表任意内容,必须用双引号引起来)
标签:Shell,格式化,FS,代码,gawk,处理,详解,awk 来源: https://www.cnblogs.com/shujk/p/13418894.html