简介
awk 是一个强大的文本分析工具,相对于 grep 的查找,sed 的编辑,awk 在其对数据分析并生成报告时,显得尤为强大。简单来说 awk 就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行各种分析处理。
举个栗子
awk -F ':' 'BEGIN {count=0;} {name[count] = $1;count++;}; END {for (i = 0; i < NR; i++) print i, name[i]}' /etc/passwd
预期结果:
1 root
2 bin
3 mail
4 ftp
...
说明
- 此处固定套路: awk -F '分隔符' ‘命令表达式’ 文件名称
- -F 参数:指定分隔符,默认为空格,此处为:
- BEGIN END 语法 : BEGIN 预置了内部变量 FS(字段分隔符)END 扩展
- NR(记录数)为固定用法,其他内置变量 如下
>
ARGC 命令行参数个数
ARGV 命令行参数排列
ENVIRON 支持队列中系统环境变量的使用
FILENAME awk 浏览的文件名
FNR 浏览文件的记录数
FS 设置输入域分隔符,等价于命令行 -F 选项
NF 浏览记录的域的个数
NR 已读的记录数
OFS 输出域分隔符
ORS 输出记录分隔符
RS 控制记录分隔符