记录awk的内置函数
awk是个优秀文本处理工具,可以说是一门程序设计语言。下面是awk内置变量。
一、内置变量表
属性 说明
?
内置变量表
$0 当前记录(作为单个变量)$1~$n当前记录的第n个字段,字段间由FS分隔FS输入字段分隔符 默认是空格NF当前记录中的字段个数,就是有多少列NR 已经读出的记录数,就是行号,从1开始RS 输入的记录他隔符默 认为换行符OFS 输出字段分隔符 默认也是空格ORS 输出的记录分隔符,默认为换行符ARGC 命令行参数个数ARGV命令行参数数组
FILENAME 当前输入文件的名字IGNORECASE 如果为真,则进行忽略大小写的匹配ARGIND 当前被处理文件的ARGV标志符CONVFMT 数字转换格式 %.6gENVIRON UNIX环境变量ERRNO UNIX系统错误消息FIELDWIDTHS 输入字段宽度的空白分隔字符串FNR 当前记录数OFMT 数字的输出格式 %.6gRSTART 被匹配函数匹配的字符串首RLENGTH 被匹配函数匹配的字符串长度SUBSEP \034?
6、输入参数获取(ARGC ,ARGV使用)
[chengmo@localhost ~]$ awk 'BEGIN{FS=":";print "ARGC="ARGC;for(k in ARGV) {print k"="ARGV[k]; }}' /etc/passwd
ARGC=2
0=awk
1=/etc/passwd
ARGC得到所有输入参数个数,ARGV获得输入参数内容,是一个数组。
?
7、获得传入的文件名(FILENAME使用)
[chengmo@localhost ~]$ awk 'BEGIN{FS=":";print FILENAME}{print FILENAME}' /etc/passwd
/etc/passwd
FILENAME,$0-$N,NF 不能使用在BEGIN中,BEGIN中不能获得任何与文件记录操作的变量。
?
8、获得linux环境变量(ENVIRON使用)
[chengmo@localhost ~]$ awk 'BEGIN{print ENVIRON["PATH"];}' /etc/passwd???
/usr/lib/qt-3.3/bin:/usr/kerberos/bin:/usr/lib/ccache:/usr/lib/icecc/bin:/usr/local/bin:/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/sbin:/usr/java/jdk1.5.0_17/bin:/usr/java/jdk1.5.0_17/jre/bin:/usr/local/mysql/bin:/home/web97/bin
ENVIRON是子典型数组,可以通过对应键值获得它的值。
?
9、输出数据格式设置:(OFMT使用)
[chengmo@localhost ~]$ awk 'BEGIN{OFMT="%.3f";print 2/3,123.11111111;}' /etc/passwd??
0.667 123.111
OFMT默认输出格式是:%.6g 保留六位小数,这里修改OFMT会修改默认数据输出格式。
?
10、按宽度指定分隔符(FIELDWIDTHS使用)
[chengmo@localhost ~]$ echo 20100117054932 | awk 'BEGIN{FIELDWIDTHS="4 2 2 2 2 3"}{print $1"-"$2"-"$3,$4":"$5":"$6}'
2010-01-17 05:49:32
FIELDWIDTHS其格式为空格分隔的一串数字,用以对记录进行域的分隔,FIELDWIDTHS="4 2 2 2 2 2"就表示$1宽度是4,$2是2,$3是2? .... 。这个时候会忽略:FS分隔符。
?
11、RSTART RLENGTH使用
[chengmo@localhost ~]$ awk 'BEGIN{start=match("this is a test",/[a-z]+$/); print start, RSTART, RLENGTH }'
11 11 4
[chengmo@localhost ~]$ awk 'BEGIN{start=match("this is a test",/^[a-z]+$/); print start, RSTART, RLENGTH }'
0 0 –1
RSTART 被匹配正则表达式首位置,RLENGTH 匹配字符长度,没有找到为-1.
?
?
?
#! /usr/bin/awk -f# player aop analyse script# author:limingjie# date:2011/12/07 {BEGIN{FSsplit("1 11 201 25 200",aopIdArr," "); split("10000 11000",srcIdArr," ");}{ for(srcId in srcIdArr){ if(srcIdArr[srcId]==$8){ for(aopId in aopIdArr){ if(aopIdArr[aopId]==$4){ # print "##################################" result[srcId"_"aopId]+=1 ; } } } }}END{ for(srcId in srcIdArr){ for(aopId in aopIdArr){ print FILENAME":"srcIdArr[srcId]"_"aopIdArr[aopId]"="result[srcId"_"aopId]; } }}?
?
参考链接:http://blah.blogsome.com/category/awk/#g_t_00bc_00c6_00cb_00e3_00d7_00dc_00ba_00cd_00b5_00c4_00bd_00c5_00b1_00be
?
?