1 前面的话awk常常用于处理数据和生成报告。它以逐行扫描的方式,查找匹配某个特定模式的文本,同时可以对匹配的行进行非常精细的操作。2 awk的格式:awk "pattern {action}" filename2.1 pattern其中pattern指的就是匹配的模式,类似于grep,不过和sed的匹配更相似。例如"/ mail /"就是匹配以mail开始的行。2.2 actionaction类似于sed在匹配模式后面跟上的命令,它的所用就是对匹配到的文本进行某种操作。例如"/ mail / {print $1}",它将匹配以mail开头的行,并将其第一个字段打印出来。3 awk的工作原理awk以一行作为输入,并将该行赋给内部变量$0;接着,awk将根据分割符将行分割成多个字段,每一个字段按照顺序存储在$1, $2… 最多可以达到100个。这个很类似shell脚本的参数,$0代表本身,$1往后是位置参数,代表每一个参数。接着awk可以对每一个字段进行相应的操作,这是grep和sed很难实现的。~$ awk "/calls/ {print $2, $5}" testSystem providedLibrary within# 首先匹配包含calls的行,接着显示第2和第5个字段。4 awk环境变量NF 字段数NR 记录数FS 分割符OFS 输出分割符