Chinaunix首页 | 论坛 | 博客
  • 博客访问: 129789
  • 博文数量: 83
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 585
  • 用 户 组: 普通用户
  • 注册时间: 2014-05-13 10:26
个人简介

- 毅力与勇气是事业的双飞翼; - 在尝试中成长,在失败中奋起。 - 概览 -> 细读 -> 概览 - 书不在多,在于精。

文章分类

全部博文(83)

文章存档

2016年(2)

2015年(6)

2014年(75)

我的朋友

分类: LINUX

2014-06-09 11:03:18

书上说:


NR,表示awk开始执行程序后所读取的数据行数.


FNR,与NR功用类似,不同的是awk每打开一个新文件,FNR便从0重新累计.


下面看两个例子:


1,对于单个文件NR 和FNR 的 输出结果一样的 :


# awk '{print NR,$0}' file1 
1 a b c d
2 a b d c
3 a c b d


#awk '{print FNR,$0}' file1 
1 a b c d
2 a b d c
3 a c b d 


2,但是对于多个文件 :


# awk '{print NR,$0}' file1 file2
1 a b c d
2 a b d c
3 a c b d
4 aa bb cc dd
5 aa bb dd cc
6 aa cc bb dd


# awk '{print FNR,$0}' file1 file2
1 a b c d
2 a b d c
3 a c b d
1 aa bb cc dd
2 aa bb dd cc
3 aa cc bb dd



在看一个例子关于NR和FNR的典型应用:  (2个文件的根据某字段合并)


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


#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


注释: (hash[key]=abc, key 唯一)


由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 -F'*' 'NR==FNR{a[FNR]=$1;b[FNR]=$2;c=FNR}NR>FNR{flag=0;for(i=1;i<=c;i++){if($2==b[i]){print a[i] $2;flag=1;break;}}if(flag==0)print}' file2 file1 >file3
阅读(436) | 评论(0) | 转发(0) |
0

上一篇:linux下使用lftp的小结

下一篇:tar命令详解

给主人留下些什么吧!~~