说明:[A][N][P][G]表示第一个支持变量的工具,[A]=awk、[N]=nawk、[P]=POSIXawk、[G]=gawkmysql
示例sql
[root@sxooky ~]# echo -e "line1 f2 f3\nline2 f4 f5\nline3 f6 f7" > a.txt [root@sxooky ~]# echo -e "test1 f2 f3 a1\ntest2 f4 f5 a2\ntest3 f6 f7 a3 a4" > b.txt [root@sxooky ~]# awk '{print "NR:"NR,"NF:"NF,"FILENAME:"FILENAME,"ARGC:"ARGC}' a.txt b.txt NR:1 NF:3 FILENAME:a.txt ARGC:3 NR:2 NF:3 FILENAME:a.txt ARGC:3 NR:3 NF:3 FILENAME:a.txt ARGC:3 NR:4 NF:4 FILENAME:b.txt ARGC:3 NR:5 NF:4 FILENAME:b.txt ARGC:3 NR:6 NF:5 FILENAME:b.txt ARGC:3
统计文件中的行数:apache
[root@sxooky ~]# cat a.txt line1 f2 f3 line2 f4 f5 line3 f6 f7 [root@sxooky ~]# awk 'END{print "NR_total:"NR}' a.txt NR_total:3
以上命令只使用了END语句块,在读入每一行的时,awk会将NR更新为对应的行号,当到达最后一行NR的值就是最后一行的行号,因此END语句块中的NR就是文件的行数。vim
每行中第一个字段的累加:数组
[root@sxooky ~]# seq 5 | awk 'BEGIN{ sum=0; print "求各字段累加总和:" } { print $1"+"; sum+=$1 } END{ print "等于"; print sum }' 求各字段累加总和: 1+ 2+ 3+ 4+ 5+ 等于 15
ORS输出记录分隔符,缺省则为换行(“\n”) 如上例bash
上例中将其内容链接到一行:ssh
[root@sxooky ~]# seq 5 | awk 'BEGIN{ sum=0; print "求各字段累加总和:";ORS="" }NR==1{print $1;sum+=$1}NR>=2{print "+"$1;sum+=$1}END{ print "="; print sum "\n"}' 求各字段累加总和: 1+2+3+4+5=15
OFS输出字段分隔符,默认为空(没有)。wordpress
[root@sxooky ~]# cat a.txt line1 f2 f3 line2 f4 f5 line3 f6 f7 [root@sxooky ~]# awk 'BEGIN{OFS=" - "}{print $1,$2,$3}' a.txt line1 - f2 - f3 line2 - f4 - f5 line3 - f6 - f7 [root@sxooky ~]# awk 'BEGIN{OFS="......"}{print $1,$2,$3}' a.txt line1......f2......f3 line2......f4......f5 line3......f6......f7
[root@sxooky ~]# awk 'BEGIN{ORS=" - "}{print}END{ORS="\n";print "\n"}' a.txt line1 f2 f3 - line2 f4 f5 - line3 f6 f7 - [root@sxooky ~]# awk 'BEGIN{ORS=" - "}{print}END{ORS="\n";print "\n"}' a.txt |awk 'BEGIN{RS=" - "}{print $1}' line1 line2 line3 [root@sxooky ~]# tail -1 /etc/passwd sxooky:x:3367:3367::/home/sxooky:/bin/bash [root@sxooky ~]# tail -1 /etc/passwd |awk 'BEGIN{RS=":"}{print $1}' sxooky x 3367 3367 /home/sxooky /bin/bash [root@sxooky ~]# tail -1 /etc/passwd |awk 'BEGIN{RS="/"}{print $1}' sxooky:x:3367:3367:: home sxooky: bin bash
[root@sxooky ~]# cd /usr/local/apache2.4/htdocs/wordpress/ [root@sxooky wordpress]# pwd /usr/local/apache2.4/htdocs/wordpress [root@sxooky wordpress]# pwd |awk -F"/" '{print $0}' /usr/local/apache2.4/htdocs/wordpress #打印最后一个字段或倒数第二个字段 [root@sxooky wordpress]# pwd |awk -F"/" '{print $NF}' wordpress [root@sxooky wordpress]# pwd |awk -F"/" '{print $(NF-1)}' htdocs
在awk中,设置有意义的域名是一种好习惯通常的变量名设置方式为 var = $n,这里var 为调用的域变量名, n为实际域号。函数
[root@sxooky ~]# tail -1 /etc/passwd sxooky:x:3367:3367::/home/sxooky:/bin/bash [root@sxooky ~]# awk -F: '{name=$1;id=$3;if(id>1000)print name "\t" id}' /etc/passwd mysql 3366 sxooky 3367
统计当前文件下面全部文件的大小之和:工具
[root@sxooky ~]# ls -al |awk 'BEGIN{total=0}{if(/^[^d]/){total+=$5;print $5"\t"$9}}END{print "total size:" total}' 36 a.txt 18 awk_var.txt 14522 .bash_history 18 .bash_logout 176 .bash_profile 176 .bashrc 48 b.txt 100 .cshrc 74454 logssh.txt 893 .mysql_history 64 .pydistutils.cfg 129 .tcshrc 8979 .viminfo total size:99613
[root@sxooky ~]# VAR=12345 [root@sxooky ~]# echo |awk -v var=$VAR '{print var}' 12345 [root@sxooky ~]# var1="abc" [root@sxooky ~]# var2="123" [root@sxooky ~]# echo |awk '{print v1 "\t" v2}' v1=$var1 v2=$var2 abc 123 [root@sxooky ~]# vim awk_var.txt
以上方法中,变量之间用空格分隔做为awk的命令行参数跟随在BEGIN、{}和END语句块以后。