【问题标题】:merge 2 lists based on first 2 columns根据前 2 列合并 2 个列表
【发布时间】:2015-01-07 22:16:09
【问题描述】:

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

文件 1:

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

文件2:

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

我需要用 file1 的第 1 列和第 2 列中的缺失值更新 file2,并添加逗号以保持相同的列数

这个例子的输出应该是这样的:

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 并加入,但我无法获得相同的结果

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

感谢您的帮助

【问题讨论】:

    标签: join awk


    【解决方案1】:

    另一种 awk 方式

    awk -F, -vOFS="," 'NR!=FNR{NF--;NF+=2}!a[$1 FS $2]++' test2 test
    

    awk -F, 'NR!=FNR{$0=$1 FS $2",,"}!a[$1 FS $2]++' test2 test
    

    最短的

    awk -F, '{x=$1","$2}NR!=FNR{$0=x",,"}!a[x]++' test2 test
    

    【讨论】:

    • 非常感谢 Jidder,所有 3 个都工作正常,我喜欢最后一个,我会将这个答案标记为已接受非常感谢您的帮助
    【解决方案2】:

    试试这条线:

    awk -F, '{k=$1 FS $2}NR==FNR{a[k]++;print;next}!a[k]{print k",,"}' file2 file1
    

    【讨论】:

    • 嗨,Kent,这工作完美我不确定命令在做什么,但非常感谢
    • @joe 没问题。我写的时候没有做测试,很高兴听到它在那里工作。
    【解决方案3】:

    使用join 命令。问题是join不能加入多个字段,所以我们需要临时操作第一个逗号:

    join -t , -o 0,2.2,2.3 -a 1 <(sed 's/,/:/' file1) <(sed 's/,/:/' file2) | sed 's/:/,/'
    

    【讨论】:

      猜你喜欢
      • 2020-03-10
      • 2020-09-04
      • 2016-01-20
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2022-06-28
      • 1970-01-01
      相关资源
      最近更新 更多