awk 命令使用入门基础详解(8)

awk '{print NR,FNR}' test.txt test2.txt 1 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 10 10 11 1 12 2 13 3 14 4

现在有两个文件格式如下:

#cat account 张三|000001 李四|000002 #cat cdr 000001|10 000001|20 000002|30 000002|15 ----------------------------------------------------------- 想要得到的结果是将用户名,帐号和金额在同一行打印出来,如下: 张三|000001|10 张三|000001|20 李四|000002|30 李四|000002|15

执行如下代码

awk -F \| 'NR==FNR{a[$2]=$0;next}{print a[$1]"|"$2}' account cdr

注释:

由NR=FNR为真时,判断当前读入的是第一个文件account,然后使用{a[$2]=$0;next}循环将account文件的每行记录都存入数组a,并使用$2第2个字段作为下标引用.

由NR=FNR为假时,判断当前读入了第二个文件cdr,然后跳过{a[$2]=$0;next},对第二个文件cdr的每一行都无条件执行 {print a[$1]"|"$2},此时变量$1为第二个文件的第一个字段,与读入第一个文件时,采用第一个文件第二个字段$2为数组下标相同.因此可以在此使用 a[$1]引用数组。

awk '{gsub(/\$/,"");gsub(/,/,""); if ($1>=0.1 && $1<0.2) c1+=1; else if ($1>=0.2 && $1<0.3) c2+=1; else if ($1>=0.3 && $1<0.4) c3+=1; else if ($1>=0.4 && $1<0.5) c4+=1; else if ($1>=0.5 && $1<0.6) c5+=1; else if ($1>=0.6 && $1<0.7) c6+=1; else if ($1>=0.7 && $1<0.8) c7+=1; else if ($1>=0.8 && $1<0.9) c8+=1; else if ($1>=0.9 ) c9+=1; else c10+=1; } END {printf "%d\t%d\t%d\t%d\t%d\t%d\t%d\t%d\t%d\t%d\t",c1,c2,c3,c4,c5,c6,c7,c8,c9,c10} ' /NEW

示例/例子

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/11866.html