系列文章目录
awk详解, 持续更新中
文章目录
前言
awk作为linux/unix命令行下的常用工具,不仅在日常工作中经常使用到,也是面试中经常会出现的考察点。该篇文章深入介绍awk的使用。有描述错误的地方欢迎指出。
一、awk是什么?
awk 是gun重要的命令行工具。该工具按照一定的模版(pattern)过滤文件的每一行,当模版匹配上后,执行定义的动作(action)。每一对pattern和action称作一个规则(rule)。规则的定义形式为
pattern { action }
pattern { action }
…
二、如何使用awk
1. 基本语法
awk 的基本语法如下
awk 'program' input-file1 input-file2
- program 为一个或者多个的
rule
(即pattern/action对)。 program 也可以通过可选参数-f
从文件中读取,后续章节中会详细介绍。 - input-file 为awk操作的文件对象(也可以是标准输入
stdin
)。awk可以同时过滤多个文件,如此处的input-file1
、inpit-file2
2. file
file 是awk的过滤对象可以一个、多个文件,甚至为空。当不指定file时,awk从标准输入stdin
中读取每一行
awk '{ print }'
line1 << 键盘输入
line1 << "print" 的打印
line2 << 键盘输入
line2 << "print" 的打印
2.1 值域(field)
awk读取文件
的每一行时,该行会被自动拆分成多个值域(field)。 默认情况下,field是根据空白符进行拆分(一个或者多个空格,一个或多个制表符)。 可以通过$
对field进行引用。例如我们有如下行
A line example for awk.
$1
为值 A
, $2
为line
, $5
为awk.
awk 的内置变量 NF
存储field个数,在该例下NF
的值为5. 我们可以直接使用 $NF
来获取到最后一个field的值 awk.
$0
的值为当前整行
➜ echo A line example for awk. | awk '{ print $0 }