免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 4485 | 回复: 16
打印 上一主题 下一主题

这一整条语句,都看不明白. [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-04-02 14:47 |只看该作者 |倒序浏览
本帖最后由 南极雨 于 2011-04-02 14:51 编辑

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 ,这个是什么情况发生的阿?
说实话,这一整条语句,都看不明白.

论坛徽章:
0
2 [报告]
发表于 2011-04-02 14:59 |只看该作者
回复 1# 南极雨


    这里的x没什么特殊用途,就是用来做个分割,你那所有的x修改成其他字符也可以,或者完全去掉都可以

论坛徽章:
0
3 [报告]
发表于 2011-04-02 15:01 |只看该作者
回复 1# 南极雨


    这条语句的意思就是当在第一个文件的时候把比如第一行变为
  AAAx001x1000.00
   然后第二个文件中的直接取第三个字段,第四个字段从第三个字符开始,最后一个字段也就是
   01 1111  AAA WW001  $$$$  1000.00
   红色部分,如果一样就打印出来了

论坛徽章:
0
4 [报告]
发表于 2011-04-02 15:02 |只看该作者
回复 3# 南极雨


    把你测试的语句贴上来看下吧。可能是写的问题

论坛徽章:
0
5 [报告]
发表于 2011-04-02 15:03 |只看该作者
回复 4# o绝对新手o


这回行了...我刚才只替换了一处,前面的换了,后面的没换...白浪费了两个多小时...郁闷!
多谢了!

还有。。。再请问:NR<=FNR 是什么时候才会出现的情况阿?

论坛徽章:
0
6 [报告]
发表于 2011-04-02 15:05 |只看该作者
回复 5# 南极雨


    FNR和NR都是文件的行数,但是当文件多余1个的时候NR是继续累加的,FNR则是重新开始结束,所以可以这样来表示不同的文件

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
7 [报告]
发表于 2011-04-02 15:06 |只看该作者
回复 1# 南极雨
  1. 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
  2. 01 1111  AAA  WW001  2460524605  1000.00
  3. 02 2222  BBB  GG001  %%%%  2000.00
  4. 04 4444  DDD  FF002  &&&&  4000.00
  5. 05 5555  EEE  RR002  @@@@  5000.00
  6. 06 666   FFF  UU003  JJJJ  6000.00

  7. 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
  8. 01 1111  AAA  WW001  2460524605  1000.00
  9. 02 2222  BBB  GG001  %%%%  2000.00
  10. 04 4444  DDD  FF002  &&&&  4000.00
  11. 05 5555  EEE  RR002  @@@@  5000.00
  12. 06 666   FFF  UU003  JJJJ  6000.00

  13. 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
  14. 01 1111  AAA  WW001  2460524605  1000.00
  15. 02 2222  BBB  GG001  %%%%  2000.00
  16. 04 4444  DDD  FF002  &&&&  4000.00
  17. 05 5555  EEE  RR002  @@@@  5000.00
  18. 06 666   FFF  UU003  JJJJ  6000.00

  19. 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
  20. 01 1111  AAA  WW001  2460524605  1000.00
  21. 02 2222  BBB  GG001  %%%%  2000.00
  22. 04 4444  DDD  FF002  &&&&  4000.00
  23. 05 5555  EEE  RR002  @@@@  5000.00
  24. 06 666   FFF  UU003  JJJJ  6000.00

复制代码
好像都没问题

论坛徽章:
0
8 [报告]
发表于 2011-04-02 15:10 |只看该作者
回复  南极雨


    FNR和NR都是文件的行数,但是当文件多余1个的时候NR是继续累加的,FNR则是重新开始 ...
o绝对新手o 发表于 2011-04-02 15:05


没听明白,多余一个是什么意思?

论坛徽章:
0
9 [报告]
发表于 2011-04-02 15:14 |只看该作者
回复 7# yinyuemi


是我写错了...不好意思!
多谢了!

论坛徽章:
0
10 [报告]
发表于 2011-04-02 15:14 |只看该作者
回复 8# 南极雨


    比如文件a 和b各有1行数据,awk首先读取第一个文件,NR和FNR相等都为1,a文件读完了然后读取b文件,这是NR变为2,FNR还是1
    这样当NR==FNR时说明在第一个文件,NR>FNR则在第二个文件中。不知道说明白没有。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP