免费注册 查看新帖 |

Chinaunix

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

[文本处理] AWK中if else循环问题?求助各位大神 [复制链接]

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 10:16:53
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-01-20 03:37 |只看该作者 |倒序浏览
各位大神,初学者求指教:
有两个文件s d,输出结果要用d的$1与s的$1对比,如果相同则输出d行全部结果及s行后几列,如果d的$1在s中$1找不到则输出当前d行
cat s
1111 something1 something2
2222 something3 something4
3333 something5 something6
4444 something7 something8 something9

cat d
4444 something10 something11
2222 something12 something13
9999 something14 something15

目标结果
4444 something10 something11 something7 something8 something9
2222 something12 something13 something3 something4
9999 something14 something15

我可以导出相匹配的行,但是加上else判断不匹配行时,输出不正常,在d中的9999结果出不来,并且加了else后,感觉多了许多空行,始终看不出来问题在哪,麻烦各位大神指点一下,谢谢

并且有一个问题想请教一下,为什么我执行后给出结果是2222在第一行而4444在第二行,AWK处理是读一行处理一行,按我理解先调用d文件,应该是先出4444的结果才对呀,是我哪里理解有问题?谢谢

bash$ awk 'NR==FNR{a[$1]=$0;next}NR>FNR{if($1 in a){print a[$1],$2,$3,$4}}' d s
2222 something12 something13  something3 something4
4444 something10 something11  something7 something8 something9

bash$ awk 'NR==FNR{a[$1]=$0;next}NR>FNR{if($1 in a){print a[$1],$2,$3,$4} else {print a[$1]}}' d s

2222 something12 something13  something3 something4

4444 something10 something11  something7 something8 something9
bash$




论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
2 [报告]
发表于 2015-01-20 07:33 |只看该作者
本帖最后由 jason680 于 2015-01-20 07:38 编辑

回复 1# yu37976285

1. read s file first
2. save it by key=$1 and value="$2 $3 $4" (without $1)
1111 something1 something2
2222 something3 something4
3333 something5 something6
4444 something7 something8 something9

$ awk 'NR==FNR{k=$1;$1="";a[k]=$0;next}NR>FNR{t=($1 in a)?a[$1]:"";print $0 t}' s d
4444 something10 something11 something7 something8 something9
2222 something12 something13 something3 something4
9999 something14 something15



awk初学之常见问题
http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=2309494&fromuid=24785593

awk数组的学习心得
http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=2312439&fromuid=24785593
   

论坛徽章:
5
白羊座
日期:2014-10-28 11:23:27水瓶座
日期:2015-01-20 10:19:022015亚冠之柏斯波利斯
日期:2015-07-11 18:17:2015-16赛季CBA联赛之同曦
日期:2015-12-23 12:38:582016猴年福章徽章
日期:2016-02-18 15:30:34
3 [报告]
发表于 2015-01-20 09:09 |只看该作者
本帖最后由 klainogn 于 2015-01-20 09:14 编辑
  1. awk 'NR==FNR{a[$1]=$0;next}{if($1 in a)$1=a[$1]}1' d s
复制代码
其实你的问题,主要是因为else分支中的a[$1]是没有值的,所以就成空行了,这个分支中应该打印的是$0吧, 不应该是a[$1]吧

论坛徽章:
4
狮子座
日期:2014-04-17 10:45:47双鱼座
日期:2014-08-21 17:16:41处女座
日期:2014-08-26 13:46:46水瓶座
日期:2014-10-28 14:08:50
4 [报告]
发表于 2015-01-20 10:50 |只看该作者
  1. awk 'NR==FNR{b[$1]=$2" "$3" "$4;next}NR>FNR{if($1 in b)print  $0 b[$1];else print $0}'
复制代码

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 10:16:53
5 [报告]
发表于 2015-01-20 19:50 |只看该作者
回复 2# jason680


  谢谢大神指导,我自己要加强学习了,谢谢
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP