对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 用法: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开头的记录为止,或到文件末尾。