首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >根据前2列合并2个列表

根据前2列合并2个列表
EN

Stack Overflow用户
提问于 2015-01-07 12:58:19
回答 3查看 62关注 0票数 1

我需要根据第1列和第2列合并2个列表

file1:

代码语言:javascript
运行
复制
client1,server1,3000.00
client1,server2,2500.00
client1,server3,1500.00
client2,server1,4500.00
client2,server2,2300.00
client2,server3,1230.00
client3,server1,3400.00
client3,server2,4500.00
client3,server3,1245.00
client4,server1,3400.00
client5,server2,4500.00
client6,server3,1245.00
client7,server1,3400.00
client7,server2,4500.00
client8,server3,1245.00
client8,server1,3400.00
client8,server2,4500.00
client9,server3,1245.00

file2:

代码语言:javascript
运行
复制
client1,server1,windows,250g
client1,server2,linux,450g
client1,server3,linux,400g
client2,server1,windows,250g
client2,server2,linux,450g
client2,server3,linux,400g
client3,server1,windows,250g
client3,server2,linux,450g
client3,server3,linux,400g

我需要的是用列1缺少的值更新file2,只更新file1的2,并添加逗号以保持相同的列数。

对于这个例子,输出应该如下所示:

代码语言:javascript
运行
复制
client1,server1,windows,250g
client1,server2,linux,450g
client1,server3,linux,400g
client2,server1,windows,250g
client2,server2,linux,450g
client2,server3,linux,400g
client3,server1,windows,250g
client3,server2,linux,450g
client3,server3,linux,400g
client4,server1,,
client5,server2,,
client6,server3,,
client7,server1,,
client7,server2,,
client8,server3,,
client8,server1,,
client8,server2,,
client9,server3,,

我试过使用awk并加入,但是我不能得到同样的结果。

如果创建新文件更容易,那么就没有问题。

谢谢你的帮忙

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-01-07 13:36:38

另一种方式

代码语言:javascript
运行
复制
awk -F, -vOFS="," 'NR!=FNR{NF--;NF+=2}!a[$1 FS $2]++' test2 test

代码语言:javascript
运行
复制
awk -F, 'NR!=FNR{$0=$1 FS $2",,"}!a[$1 FS $2]++' test2 test

最短

代码语言:javascript
运行
复制
awk -F, '{x=$1","$2}NR!=FNR{$0=x",,"}!a[x]++' test2 test
票数 1
EN

Stack Overflow用户

发布于 2015-01-07 13:13:49

试一试这一行:

代码语言:javascript
运行
复制
awk -F, '{k=$1 FS $2}NR==FNR{a[k]++;print;next}!a[k]{print k",,"}' file2 file1
票数 1
EN

Stack Overflow用户

发布于 2015-01-07 14:15:09

使用join命令。问题是join无法在多个字段上连接,因此我们需要临时操作第一个逗号:

代码语言:javascript
运行
复制
join -t , -o 0,2.2,2.3 -a 1 <(sed 's/,/:/' file1) <(sed 's/,/:/' file2) | sed 's/:/,/'
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27820056

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档