awk 行输出,字段输出,readline 及awk 数组

awk

1 工作原理

逐行读取文本,默认以空格或tab键为分隔符进行分隔,将分隔所得的各个字段保存到内建变量中,并按模式或者条件执行编辑命

sed命令常用于一整行的处理, 而awk比较倾向于将一行分成多个"字段"然后再进行处理。awk信息的读入也是逐行读取的,执行结果可以通过print的功能将字段数据打印显示。

在使用awk命令的过程中,可以使用逻辑操作符“&&"表示“与"、"|| "表示“或"、"!"表示“非";还可以进行简单的数学运算,如+、-、*、/、%、^分别表示加、减、乘、除、取余和乘方


2 格式

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

awk -f 脚本文件 文件1 文件2

注意:awk 里


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

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

4 按行输出文本

image-20210726175227896

image-20210726175701622

image-20210726175852585

image-20210726180127343

image-20210726204211857


5 BEGIN模式和END 模式

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

BEGIN 和 END 中的命令只会执行一次

awk ' BEGIN{}; { } ; END{}'

image-20210726205015028


6 按字段输出文本

image-20210726205229026

img

img

image-20210726205559269

image-20210726210149318

image-20210726210800559

image-20210726210930623

image-20210726211147827

image-20210726211435215

img


7 通过管道,双引号调用 shell 命令

image-20210726212259735

image-20210726212629587

image-20210726215605938

image-20210726220434264

image-20210726221757588


8 getline

当getline左右无重定向符“<”或“|”时, awk 首先读取到了第一行,然后getlinie就得到了第一行下面的1行,也就是第二行 。 getline 之后,awk 会改变对应的NF,NR 吗,FNR ,$0 等内部变量,所以此时,$0 的值就不再是第一行的值,而是第二行的。然后将它打印出来

当getline 左右两边有重定向"<" 或 "|" 时,getline 则作用于定向输入文件,由于该文件是刚打开,并没有被awk 读入,只是getline 读入,那么getline 返回的是该文件的第一行,而不是隔行.

image-20210726222904955

image-20210726224222221


9 awk 与数组

awk 数组的下标除了可以使用数字,也可以使用字符串。使用字符串作为数组下标,需要给字符串加上双引号""

image-20210726224836832

image-20210726225424816

image-20210726230534032

image-20210726230723911

posted @ 2021-07-27 10:20  知己一语  阅读(2788)  评论(0编辑  收藏  举报