Linux使用之awk

2017/04/14 Linux

awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大。简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行各种分析处理。

使用方法

awk [-F field-separator] 'commands' input-file(s)

  • [-F域分隔符]是可选的,默认为空格
  • commands 是真正awk命令
  • input-file(s) 是待处理的文件
  • awk工作流程是这样的:读入有’\n’换行符分割的一条记录,然后将记录按指定的域分隔符划分域,填充域,$0则表示所有域,$1表示第一个域,$n表示第n个域。

awk脚本:

  • BEGIN{ 这里面放的是执行前的语句 }
  • {这里面放的是处理每一行时要执行的语句}
  • END {这里面放的是处理完所有的行后要执行的语句 }

内置变量

ARGC 命令行参数个数

ARGV 命令行参数排列

ENVIRON 支持队列中系统环境变量的使用

FILENAME awk浏览的文件名

FNR 浏览文件的记录数

FS 设置输入域分隔符,等价于命令行 -F选项

NF 浏览记录的域的个数

NR 已读的记录数

OFS 输出域分隔符

ORS 输出记录分隔符

RS 控制记录分隔符

常用场景

打印某一列

awk -F '\t' '{print $1}'

计算某列和

cat test.txt | awk '{sum+=$2} END {print sum}'

  • sum默认初始化为0。
Show Disqus Comments

Search

    Post Directory