awk 简单教程

来源:互联网 发布:阿里云备案换服务器 编辑:程序博客网 时间:2024/06/06 03:17

对awk -F做一个简单的介绍:

 awk -F"\t" '{print $3}'  test.txt 

等同于

awk -F'\t' '{print $3}'  test.txt

”-F“后用单/双引号均可以,结果一样。区别是:shell对单引号中的内容不解释,直接传给awk,而对双引号中的内容解释后再传给awk。 

另外使用awk '{print $3}' OFS="\t"  test.txt也可以达到同样效果。


如果省略不写,默认分隔符也是水平分隔符\t


awk简明教程,一篇通:http://coolshell.cn/articles/9070.html

简单的实例,快速上手:http://www.cnblogs.com/repository/archive/2011/05/13/2045927.html

第二篇已引入我的文章(可直接参考):http://blog.csdn.net/longshenlmj/article/details/42394181

 

awk 用法:awk ' pattern {action} ' 


变量名 含义
ARGC 命令行变元个数
ARGV 命令行变元数组
FILENAME 当前输入文件名
FNR 当前文件中的记录号
FS 输入域分隔符,默认为一个空格
RS 输入记录分隔符
NF 当前记录里域个数
NR 到目前为止记录数
OFS 输出域分隔符
ORS 输出记录分隔符


典型实例:

   awk '/101/'  file: 显示文件file中包含101的匹配行。
   awk '/101/,/105/'  file
   awk '$1 == 5'    file
   awk '$1 == "CT"' file 注意必须带双引号
   awk '$1 * $2 >100 '  file
   awk '$2 >5 && $2<=15' file

  Flag=abcd   awk '{print '$Flag'}' 结果为abcd   awk '{print "$Flag"}' 结果为$Flag

求和:

   awk 'BEGIN{total=0}{total+=$4}END{print total}' a.txt   -----对a.txt文件的第四个域进行求和!

  • $ awk '/^(no|so)/' test-----打印所有以模式no或so开头的行。

  • $ awk '/^[ns]/{print $1}' test-----如果记录以n或s开头,就打印这个记录。

  • $ awk '$1 ~/[0-9][0-9]$/(print $1}' test-----如果第一个域以两个数字结束就打印这个记录。

  • $ awk '$1 == 100 || $2 < 50' test-----如果第一个或等于100或者第二个域小于50,则打印该行。

  • $ awk '$1 != 10' test-----如果第一个域不等于10就打印该行。

  • $ awk '/test/{print $1 + 10}' test-----如果记录包含正则表达式test,则第一个域加10并打印出来。

  • $ awk '{print ($1 > 5 ? "ok "$1: "error"$1)}' test-----如果第一个域大于5则打印问号后面的表达式值,否则打印冒号后面的表达式值。

  • $ awk '/^root/,/^mysql/'  test----打印以正则表达式root开头的记录到以正则表达式mysql开头的记录范围内的所有记录。如果找到一个新的正则表达式root开头的记 录,则继续打印直到下一个以正则表达式mysql开头的记录为止,或到文件末尾。