awk工作原理

1、awk工作原理

  • 逐行读取文本,默认以空格或tab键为分隔符进行分隔,将分隔所得的各个字段保存到内建变量中,并按模式或者条件执行编辑命令
  • sed命令常用于一整行的处理,而awk比较倾向于将一行分成多个"字段",然后再进行处理。awk信息的读入也是逐行读取的,执行结果可以通过print的功能将字段数据打印显示。在使用awk命令的过程中,可以使用逻辑操作符"&&“表示"与”、"||'表示"或"、"!“表示"非”;还可以进行简单的数学运算,如+、-、*、/、%、^分别表示加、减、乘、除、取余和乘方

2、命令格式

awk 选项 '模式或条件 {操作} ' 文件1 文件2 ...
awk -f 脚本文件 文件1 文件2...

3、awk常见的内建变量(可直接用)

FS :列分割符。指定每行文本的字段分隔符,默认为空格或制表位。与"-F"作用相同
NF :当前处理的行的字段个数
NR :当前处理的行的行号(序数)
$0 :当前处理的行的整行内容
$n :当前处理行的第n个字段(第n列)
FILENAME :被处理的文件名
RS :行分隔符。awk从文件上读取资料时,将根据RS的定义把资料切割成许多条记录,而awk一次仅读入一条记录,以进行处理。预设值是'\n'

4、按行输出文本

在这里插入图片描述
在这里插入图片描述

  • BEGIN模式表示,在处理指定的文本之前,需要先执行BEGIN模式中的指定的动作;awk再处理指定的文本,之后再执行END模式中的指定动作,END{}语句块中,往往会放入打印结果等语句

5、按字段输出文本

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

6、通过管道、双引号调用 Shell 命令

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

7、getline

  • 当getline左右无重定向符“<”或“|”时,getline作用于当前文件,读入当前文件的第一行给其后跟的变量var或$0;应该注意到,由于awk在处理getline之前已经读入了一行,所以getline得到的返回结果是隔行的
  • 当getline左右有重定向符“<”或“|”时,getline则作用于定向输入文件,由于该文件是刚打开,并没有被awk读入一行,只是getline读入,那么getline返回的是该文件的第一行,而不是隔行
    在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_53496478/article/details/114923227
awk
今日推荐