码迷,mamicode.com
首页 > 其他好文 > 详细

awk中的NR FNR

时间:2015-07-17 16:22:27      阅读:122      评论:0      收藏:0      [点我收藏+]

标签:

shell编程中,awk简直就是一把利器,你可以把它看成shell的一部分,也可以看成一种单独的语言,功能十分强大。今天先来说一说NR与FNR

先准备两个文件:

1.txt,内容为:

user password

wolf 123456

zys 123

2.txt 内容为:

id user

0001 wolf

0002 xiaozhai

其实在处理单个文件时,NR与FNR都一样,表示当前读取的行号,如执行awk ‘{print NR}‘ 1.txt 和执行 awk ‘{print FNR}‘ 1.txt,结果都一样,均为

1

2

3

但是当处理两个文件时,awk先读取第一个文件,此时NR与FNR相等,但是当读取第二个文件时,FNR从新开始计数,而NR继续增长,此时就不相等了,

执行awk ‘{print NR"\t"FNR}‘ 1.txt 2,txt 结果如下:

1 1

2 2

3 3

4 1

5 2

6 3

借助这个特性,结合awk的循环和数组,awk非常适合处理查找两个文件中有相同记录域的关联信息,如查找存在于1.txt中的用户,且此用户也存在于2.txt中的密码,最后打印用户名和对应的密码, awk ‘NR==FNR{a[$1]=$2;next} {if(a[$2]){print $2"\t"a[$2];}}‘ 1.txt 2.txt ,注意一定要用单引号,结果为:

user passwd

wolf 123456


解释一下这个命令:当NR==FNR时,即读取第一个文件的时候,先用循环把1.txt中的信息存到数组a中;当NR不等于FNR时,即读取第二个文件的时候,此时$2对应与2.txt中user列,若数组a中有对应与当前行user的记录,则打印user(即$2)和passwd(即a[$2])。

awk的功能由此可见真是很强大。



版权声明:本文为博主原创文章,未经博主允许不得转载。

awk中的NR FNR

标签:

原文地址:http://blog.csdn.net/wolfzhaoshuai/article/details/46926625

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!