gpt4 book ai didi

linux - 将制表符分隔值文件的 x 列与第二个 tsv 文件的 x 列交换

转载 作者:太空宇宙 更新时间:2023-11-04 09:13:17 25 4
gpt4 key购买 nike

假设我有:

文件1.tsv

Foo\tBar\tabc\t123
Bla\tWord\tabc\tqwer
Blub\tqwe\tasd\tqqq

文件2.tsv

123\tzxcv\tAAA\tqaa
asd\t999\tBBB\tdef
qwe\t111\tCCC\tabc

我想用 file2.tsv 的第 3 列覆盖 file1.tsv 的第 3 列以结束:

Foo\tBar\tAAA\t123
Bla\tWord\tBBB\tqwer
Blub\tqwe\tCCC\tqqq

在 bash 中执行此操作的好方法是什么?

最佳答案

看看这个 awk:

awk 'FNR==NR{a[NR]=$3;next}{$3=a[FNR]}1' OFS='\t' file{2,1}.tsv > output.tsv

如果您只想使用 bash,只需付出一点努力:

while IFS=$'\t' read -r a1 a2 _ a4; do
IFS=$'\t' read -ru3 _ _ b3 _
printf '%s\t%s\t%s\t%s\n' "$a1" "$a2" "$b3" "$a4"
done <file1.tsv 3<file2.tsv >output.tsv

输出:

Foo     Bar     AAA     123
Bla Word BBB qwer
Blub qwe CCC qqq

关于linux - 将制表符分隔值文件的 x 列与第二个 tsv 文件的 x 列交换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52055453/

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