变量名 含义
ARGC 命令行变元个数
ARGV 命令行变元数组
FILENAME 当前输入文件名
FNR 当前文件中的记录号
FS 输入域分隔符,默认为一个空格
RS 输入记录分隔符
NF 当前记录里域个数
NR 到目前为止记录数
OFS 输出域分隔符
ORS 输出记录分隔符
1、awk '/101/' file 显示文件file中包含101的匹配行。
awk '/101/,/105/' file 显示文件file中包含101,或者包含105的匹配行。
awk '/101/ && /105/' file 显示文件file中包含101并且包含105的匹配行。
awk '$1 == 5' file
awk '$1 == "CT"' file 注意必须带双引号
awk '$1 * $2 >100 ' file
awk '$2 >5 && $2<=15' file
2、awk '{print NR,NF,$1,$NF}' file 显示文件file的当前记录号、域数和每一行的第一个和最后一个域。
awk '/101/ {print $1,$2 + 10}' file 显示文件file的匹配行的第一、二个域加10。
awk '/101/ {print $1","$2}' file 显示文件file的匹配行的第一、二个域,中间逗号分隔。
awk '/101/ {print $1"\t"$2}' file 显示文件file的匹配行的第一、二个域,中间table分隔。
awk '/101/ {print $1 $2}' file 显示文件file的匹配行的第一、二个域,但显示时域中间没有分隔符。
3、df | awk '$4>1000000 ' 通过管道符获得输入,如:显示第4个域满足条件的行。
4、cat /etc/passwd |awk -F ":" '{print $1}' 按照新的分隔符“:”进行操作。
cat /etc/passwd |awk 'BEGIN{FS=":"} {print $1}' 按照新的分隔符“:”进行操作。
Sep=":"
cat /etc/passwd |awk -F $Sep '{print $1}' 按照环境变量Sep的值做为分隔符
awk -F '[ :\t|]' '{print $1}' file 按照正则表达式的值做为分隔符,这里代表空格、:、TAB、|同时做为分隔符。
awk -F '[][]' '{print $1}' file 按照正则表达式的值做为分隔符,这里代表[、]
5、ls -l |awk '$7 ~ /12/ {print $0}' 显示文件中第7个域匹配12的行(记录)。
6. ls -l |awk 'BEGIN {OFS="%"} {print $1,$2}' 过设置输出分隔符(OFS="%")修改输出格式。
ls -l |awk 'BEGIN {OFS="\t"} {print $1,$2}' 过设置输出分隔符(OFS="\t")修改输出格式。
7 df |grep -v Available| awk 'BEGIN {max=100; print "max=" max} {max=($4 > max ?$4:max); print $4,"Now max is\t" max}'
更多信息请查看 http://sebug.net/paper/books/awk/