这一整条语句,都看不明白.
时间:2011-04-02
来源:互联网
http://bbs.chinaunix.net/viewthread.php?tid=577044
这里的第六个例子...
6、
file1的第一列与file2的第3列相同,
file1的第二列与file2的第4列的3-5位相同,
file1的第三列与file2的最后一列相同,
# cat file1
AAA 001 1000.00
BBB 001 2000.00
DDD 002 4000.00
EEE 002 5000.00
FFF 003 6000.00
# cat file2
01 1111 AAA WW001 $$$$ 1000.00
02 2222 BBB GG001 %%%% 2000.00
03 3333 CCC JJ001 **** 3000.00
04 4444 DDD FF002 &&&& 4000.00
05 5555 EEE RR002 @@@@ 5000.00
06 666 FFF UU003 JJJJ 6000.00
07 777 III II005 PPPP 7000.00
08 8888 TTT TT008 TTTT 8000.00
1. # awk 'NR<=FNR{a[$1]=$1"x"$2"x"$3}
2. > NR>FNR{b=substr($4,3);c=$3"x"b"x"$6;if(c==a[$3]) print}' file1 file2
3. 01 1111 AAA WW001 $$$$ 1000.00
4. 02 2222 BBB GG001 %%%% 2000.00
5. 04 4444 DDD FF002 &&&& 4000.00
6. 05 5555 EEE RR002 @@@@ 5000.00
7. 06 666 FFF UU003 JJJJ 6000.00
a[$1]=$1"x"$2"x"$3 c=$3"x"b"x"$6 这里的" x "是什么意思啊?我发现换成空或者y和其他的字符都不可以,返回空.就只有用x
再就是NR<=FNR ,这个是什么情况发生的阿?
说实话,这一整条语句,都看不明白.
作者: 南极雨 发布时间: 2011-04-02
这里的x没什么特殊用途,就是用来做个分割,你那所有的x修改成其他字符也可以,或者完全去掉都可以
作者: o绝对新手o 发布时间: 2011-04-02
这条语句的意思就是当在第一个文件的时候把比如第一行变为
AAAx001x1000.00
然后第二个文件中的直接取第三个字段,第四个字段从第三个字符开始,最后一个字段也就是
01 1111 AAA WW001 $$$$ 1000.00
红色部分,如果一样就打印出来了
作者: o绝对新手o 发布时间: 2011-04-02
把你测试的语句贴上来看下吧。可能是写的问题
作者: o绝对新手o 发布时间: 2011-04-02
这回行了...我刚才只替换了一处,前面的换了,后面的没换...白浪费了两个多小时...郁闷!
多谢了!
还有。。。再请问:NR<=FNR 是什么时候才会出现的情况阿?
作者: 南极雨 发布时间: 2011-04-02
FNR和NR都是文件的行数,但是当文件多余1个的时候NR是继续累加的,FNR则是重新开始结束,所以可以这样来表示不同的文件
作者: o绝对新手o 发布时间: 2011-04-02
- awk 'NR<=FNR{a[$1]=$1"x"$2"x"$3} NR>FNR{b=substr($4,3);c=$3"x"b"x"$6;if(c==a[$3]) print}' f1 f2
- 01 1111 AAA WW001 2460524605 1000.00
- 02 2222 BBB GG001 %%%% 2000.00
- 04 4444 DDD FF002 &&&& 4000.00
- 05 5555 EEE RR002 @@@@ 5000.00
- 06 666 FFF UU003 JJJJ 6000.00
-
- awk 'NR<=FNR{a[$1]=$1"y"$2"y"$3} NR>FNR{b=substr($4,3);c=$3"y"b"y"$6;if(c==a[$3]) print}' f1 f2
- 01 1111 AAA WW001 2460524605 1000.00
- 02 2222 BBB GG001 %%%% 2000.00
- 04 4444 DDD FF002 &&&& 4000.00
- 05 5555 EEE RR002 @@@@ 5000.00
- 06 666 FFF UU003 JJJJ 6000.00
-
- awk 'NR<=FNR{a[$1]=$1 FS $2 FS $3} NR>FNR{b=substr($4,3);c=$3 FS b FS$6;if(c==a[$3]) print}' f1 f2
- 01 1111 AAA WW001 2460524605 1000.00
- 02 2222 BBB GG001 %%%% 2000.00
- 04 4444 DDD FF002 &&&& 4000.00
- 05 5555 EEE RR002 @@@@ 5000.00
- 06 666 FFF UU003 JJJJ 6000.00
-
- awk 'NR<=FNR{a[$1]=$1 $2 $3} NR>FNR{b=substr($4,3);c=$3 b $6;if(c==a[$3]) print}' f1 f2
- 01 1111 AAA WW001 2460524605 1000.00
- 02 2222 BBB GG001 %%%% 2000.00
- 04 4444 DDD FF002 &&&& 4000.00
- 05 5555 EEE RR002 @@@@ 5000.00
- 06 666 FFF UU003 JJJJ 6000.00
作者: yinyuemi 发布时间: 2011-04-02
FNR和NR都是文件的行数,但是当文件多余1个的时候NR是继续累加的,FNR则是重新开始 ...
o绝对新手o 发表于 2011-04-02 15:05
没听明白,多余一个是什么意思?
作者: 南极雨 发布时间: 2011-04-02
是我写错了...不好意思!
多谢了!
作者: 南极雨 发布时间: 2011-04-02
比如文件a 和b各有1行数据,awk首先读取第一个文件,NR和FNR相等都为1,a文件读完了然后读取b文件,这是NR变为2,FNR还是1
这样当NR==FNR时说明在第一个文件,NR>FNR则在第二个文件中。不知道说明白没有。。
作者: o绝对新手o 发布时间: 2011-04-02
这个我明白,就是NR<FNR的情况是什么时候?
作者: 南极雨 发布时间: 2011-04-02
劳驾SS,再请问一下:NR<=FNR 是什么时候才会出现的情况阿?
作者: 南极雨 发布时间: 2011-04-02
应该不会有那种情况
作者: o绝对新手o 发布时间: 2011-04-02
这个例子中,把 NR<=FNR改成NR=FNR,输出也为空...改称NR<FNR 也是一样的
作者: 南极雨 发布时间: 2011-04-02
只有NR==FNR,和NR>FNR的情况,没有NR<FNR, 那个例子中的NR<=FNR成立,不是因为NR<FNR,而是NR==FNR.
- awk '{print "NR = "NR, " FNR = "FNR}' <(seq 5) <(seq 5)
- NR = 1 FNR = 1
- NR = 2 FNR = 2
- NR = 3 FNR = 3
- NR = 4 FNR = 4
- NR = 5 FNR = 5
- NR = 6 FNR = 1
- NR = 7 FNR = 2
- NR = 8 FNR = 3
- NR = 9 FNR = 4
- NR = 10 FNR = 5
作者: yinyuemi 发布时间: 2011-04-02
我又搞错了...应该是 == 不是 =
不好意思了!
作者: 南极雨 发布时间: 2011-04-02
原来这样啊...这么看起来这个例子简单多了...呵呵 , 多谢多谢!
作者: 南极雨 发布时间: 2011-04-02
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28