gpt4 book ai didi

unix - 将列添加到 ID 匹配的另一个文件中的文件

转载 作者:行者123 更新时间:2023-12-01 10:57:44 24 4
gpt4 key购买 nike

我有这样一个文件:-

123,Bob
456,Joe
789,Jane

还有这样一个文件

456,abc,Red
789,def,Yellow

我想将文件 2 中的第 3 列添加到文件 1,但仅在第一列匹配的地方添加,结果如下所示:-

123,Bob
456,Joe,Red
789,Jane,Yellow

我在 Cygwin 命令行上有任何可用的工具来执行此操作,例如awk、粘贴等

最佳答案

如果你有 paste,你也应该有 join 是为这类事情设计的。假设输入文件按您可以说的键排序:

join -t, in1 in2

输出:

456,Joe,Red
789,Jane,Yellow

根据新要求进行编辑

您可以使用 -o 开关:

join -t, -o 1.1,1.2,2.3 in1 in2

你似乎想保留第一个文件中未配对的行,在这种情况下使用 -a1:

join -t, -o 1.1,1.2,2.3 -a1 in1 in2

输出:

123,Bob,
456,Joe,Red
789,Jane,Yellow

这会在不成对的行末尾留下一个无关的逗号,但可以用 | 删除它sed 's/,$//'.

关于unix - 将列添加到 ID 匹配的另一个文件中的文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13970018/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com