欢迎来到天天文库
浏览记录
ID:32366625
大小:40.79 KB
页数:18页
时间:2019-02-03
《linuxawk简简单单》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、Linuxawk简简单单 2009-08-2521:02:41
2、 分类:computer-linux
3、 标签:
4、字号大中小 订阅awk非常的优秀,运行效率高,而且代码简单,对格式化的文本处理能力超强。基本上grep和sed能干的活awk全部都能干,而且干得更好。先来一个很爽的例子:文件a,统计文件a的第一列中是浮点数的行的浮点数的平均值。用awk来实现只需要一句话就可以搞定(当然,这个东东用python也可以很轻松的实现,只是无论如何都得新建一个文件;别妄想用bashshell来做,那可是浮点数!!!)$cata1.021331#.ll 442.536ss
5、 7awk'BEGIN{total=0;len=0}{if($1~/^[0-9]+.[0-9]*/){total+=$1;len++}}END{printtotal/len}'aniubility!awk的语法:awk[-Fre][parameter...]['program'][-f'programfile'][in_file_list]awk里面的BEGIN,END结构:BEGIN和END中的语句分别在开始读取文件(in_file)之前和读取完文件之后发挥作用,可以理解为初始化和扫尾。awk里面的if..else; while;do..while;fo
6、r;break;continue;printf语法都和C语言的语法一致;而且awk支持使用if(keyinarray)这样的判断语句(其中,array是数组,这一点和python的语法非常相像。);awk支持使用for(keyinarray)这样的语法来遍历数组(也是和python的语法很相像。)我会用的参数的说明:-Fre:允许awk更改其字段分隔符-vvar=val把val值赋值给var(变量通信的好方法啊~~今天才知道这个选项,想想之前写的代码,抓狂啊~~)如果有多个变量要赋值,那么就写多个-v,每个变量赋值对应一个-ve.g.要打印文件a的第num行到nu
7、m+num1行之间的行,awk-vnum=$num-vnum1=$num1'NR==num,NR==num+num1{print}'a-fprogfile:允许awk调用并执行progfile程序文件,当然progfile必须是一个符合awk语法的程序文件我会用的awk内置变量:ARGC 命令行参数的个数ARGV:命令行参数数组ARGIND当前被处理文件的ARGV标志符e.g有两个文件a和bawk'{if(ARGIND==1){print"处理a文件"}if(ARGIND==2){print"处理b文件"}}'ab文件处理的顺序是先扫描完a文件,再扫描b文件N
8、R已经读出的记录数FNR 当前文件的记录数上面的例子也可以写成这样:awk'NR==FNR{print"处理文件a"}NR>FNR{print"处理文件b"}'ab输入文件a和b,由于先扫描a,所以扫描a的时候必然有NR==FNR,然后扫描b的时候,FNR从1开始计数,而NR则接着a的行数继续计数,所以NR>FNRe.g要显示文件的第10行至第15行awk'NR==10,NR==15{print}'aFS输入字段分隔符(缺省为:space:),相当于-F选项awk-F':''{print}'a 和 awk'BEGIN{FS=":"}{print}'a是一样
9、的OFS输出字段分隔符(缺省为:space:)awk-F':''BEGIN{OFS=";"}{print$1,$2,$3}'b如果catb为1:2:34:5:6那么把OFS设置成";"后就会输出1;2;34;5;6(小注释:awk把分割后的第1、2、3个字段用$1,$2,$3...表示,$0表示整个记录(一般就是一整行))NF:当前记录中的字段个数awk-F':''{printNF}'b的输出为33表明b的每一行用分隔符":"分割后都3个字段可以用NF来控制输出符合要求的字段数的行,这样可以处理掉一些异常的行awk-F':''{if(NF==3)print}'bR
10、S:输入记录分隔符,缺省为""缺省情况下,awk把一行看作一个记录;如果设置了RS,那么awk按照RS来分割记录例如,如果文件c,catc为helloworld;Iwanttogoswimmingtomorrow;hiahia运行awk'BEGIN{RS=";"}{print}'c的结果为helloworldIwanttogoswimmingtomorrowhiahia合理的使用RS和FS可以使得awk处理更多模式的文档,例如可以一次处理多行,例如文档dcatd的输出为123456789101112hello每个记录使用空行分割,每个字段使用换行符分割,这样的
11、awk也很
此文档下载收益归作者所有