1 工作原理
逐行读取文本,
默认以空格或tab键为分隔符
进行分隔,将分隔所得的各个字段
保存到内建变量中
,并按模式或者条件执行编辑命
sed命令常用于一整行的处理, 而awk比较倾向于将一行分成多个"字段"然后再进行处理。awk信息的读入也是逐行读取的,执行结果可以通过print的功能将字段数据打印显示。
在使用awk命令的过程中,可以使用逻辑操作符“
&&
"表示“与"、"
||
"表示“或"、"
!
"表示“非";还可以进行简单的数学运算,如
+、-、*、/、%、^
分别表示加、减、乘、除、取余和乘方
awk 选项 '模式或条件 {操作} ' 文件 1 文件 2 .......
awk -f 脚本文件 文件1 文件2
注意:awk 里
3 awk 常见的内建变量(可以直接使用)
输入字段列分隔符。指定每行文本的字段分隔符,默认使用空格或者制表位。与 “-F” 相同
输出字段列分隔符
当前处理的行的字段个数
当前处理行的行号(序号)
当前处理的行的整行内容
当前处理行的第n个字段(第n列)
FILENAME
被处理的文件名
行分隔符。awk 从文件读取资料是,将根据RS的定义把资料切割成许多条记录,而awk 一次仅读入一条记录,以进行处理。预设值是'\n'
4 按行输出文本
5 BEGIN模式和END 模式
BEGIN 模式,在处理指定的文本之前,需要
先执行BEGIN模式
中指定的动作。
awk再处理指定的文本
。之后,
再执行END模式
中指定的动作。END{}语句块中,往往会放入打印结果等语句。
BEGIN 和 END 中的命令只会执行一次
awk ' BEGIN{}; { } ; END{}'
6 按字段输出文本
8 getline
当getline左右无重定向符“<”或“|”时, awk 首先读取到了第一行,然后getlinie就得到了第一行下面的1行,也就是第二行 。 getline 之后,awk 会改变对应的NF,NR 吗,FNR ,$0 等内部变量,所以此时,$0 的值就不再是第一行的值,而是第二行的。然后将它打印出来
当getline 左右两边有重定向"<" 或 "|" 时,getline 则作用于定向输入文件,由于该文件是刚打开,并没有被awk 读入,只是getline 读入,那么getline 返回的是该文件的第一行,而不是隔行.
9 awk 与数组
awk 数组的下标除了可以使用数字,也可以使用字符串。
使用字符串作为数组下标
,需要给字符串加上
双引号""