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
示例/例子: