免费注册 查看新帖 |

Chinaunix

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

請教:如何用Shell 在file1.txt中增加一列 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-08-26 21:21 |只看该作者 |倒序浏览
請教各位前輩,同一Path下有2個txt檔案,都是以TAB分隔的:


file1.txt (無title,只有數據)
Emp_id  Emp_name Company  Dept_id
1001      A                 甲               10
1002      B                 乙               10
1003      C                 丙               20
...

file2.txt (無title,只有數據)
Company Dept_id  Dept_name
甲            10           財務部
乙            10           業務部
丙            10           采購部

通過連接條件 file1的 Company  = file2的 Company  and  file1的 Dept_id = file2的 Dept_id

執行程式后的結果為
file1檔案中(title不需要的,只要數據即可):
Emp_id  Emp_name Company  Dept_id  Dept_name
1001      A                 甲        10           財務部
1002      B                 乙        10           業務部
1003      C                 丙        20
...
結果需注意 1 漢字不要有亂碼。
           2 要以tab分隔。


我的環境 SunOS 5.10,請各位幫忙,謝謝。

论坛徽章:
0
2 [报告]
发表于 2008-08-26 21:54 |只看该作者
  1. awk -F'\t' 'NR==FNR{a[$1$2]=$3}NR!=FNR{print $0,"\t"a[$3$4]}' file2 file1
复制代码


不知道你的系统支持不支持

[ 本帖最后由 merlin852 于 2008-8-26 21:57 编辑 ]

论坛徽章:
0
3 [报告]
发表于 2008-08-27 10:20 |只看该作者
原帖由 merlin852 于 2008-8-26 21:54 发表
awk -F'\t' 'NR==FNR{a[$1$2]=$3}NR!=FNR{print $0,"\t"a[$3$4]}' file2 file1

不知道你的系统支持不支持

感謝您幫忙,執行了一下,生成結果不是想要的,不知還有無其他方法

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
4 [报告]
发表于 2008-08-27 10:47 |只看该作者
awk 'NR==FNR{a[$1,$2]=$3}NR!=FNR{print $0,"\t"a[$3,$4]}' file2 file1

看懂人家的思路,自己改改

论坛徽章:
1
处女座
日期:2014-12-23 17:59:27
5 [报告]
发表于 2008-08-27 11:04 |只看该作者
通過連接條件 file1的 Company  = file2的 Company  and  file1的 Dept_id = file2的 Dept_id


这样的话, 就不会有1003吧?

论坛徽章:
0
6 [报告]
发表于 2008-08-27 13:05 |只看该作者
awk -F'\t' 'NR==FNR{a[$1$2]=$3}NR!=FNR{print $0,"\t"a[$3$4]}' file2 file1

這個是說對于file2,當NR==FNR時 執行 a[$1$2]=$3 ,當 NR!=FNR時, 就print file1 + tab + a[$3$4]
這里 a[$1$2]=$3 和a[$3$4] 是什么含義,是分別指file2和file1的嗎? 感覺不太理解哦...

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
7 [报告]
发表于 2008-08-27 13:10 |只看该作者
这是awk数组的一个典型应用,看看新手导航里的那个awk教程链接

论坛徽章:
0
8 [报告]
发表于 2008-08-27 16:35 |只看该作者
http://bbs.chinaunix.net/viewthr ... 1%26filter%3Ddigest

感谢前辈,学习了下,有点思路了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP