bash - instersection из двух файлов, основанных на определенных столбцах?

, я хочу сделать следующее и был бы очень признателен, если бы кто-нибудь мог мне помочь в этом:

У меня есть 2 файла с разделителями табуляции с именами File1.txt и File2.txt (показано ниже). Если второй столбец (целое число) в File1.txt находится в третьем столбце (целое число) файла File2.txt, то я хочу сделать new_File1.txt и new_File2.txt и продолжать добавлять ряды.

File1.txt:

1   80  xyc
1   304 xyv
1   813653  xyb
1   813661  xyn
1   954653  xym

File2.txt:

abvb    1   178
aaa 1   304 
ttt 1   353
ggg 1   98971
ghj 1   813653

Так, например, мой new_File1.txt будет выглядеть так:

new_File1.txt:

1   304 xyv
1   813653  xyb

new_File2.txt:

aaa     1   304
ghj     1   813653

Спасибо всем за ваше Помогите! Я использовал:

join -1 2 -2 3 -t '\t' file1.txt file2.txt

, но это дает мне следующий результат:

\1      80      xyc\abvb        1       178
\1      80      xyc\aaa 1       304
\1      80      xyc\ttt 1       353
\1      80      xyc\ggg 1       98971
\1      80      xyc\ghj 1       813653
\1      304     xyv\abvb        1       178
\1      304     xyv\aaa 1       304
\1      304     xyv\ttt 1       353
\1      304     xyv\ggg 1       98971
\1      304     xyv\ghj 1       813653
\1      813653  xyb\abvb        1       178
\1      813653  xyb\aaa 1       304
\1      813653  xyb\ttt 1       353
\1      813653  xyb\ggg 1       98971
\1      813653  xyb\ghj 1       813653
\1      813661  xyn\abvb        1       178
\1      813661  xyn\aaa 1       304
\1      813661  xyn\ttt 1       353
\1      813661  xyn\ggg 1       98971
\1      813661  xyn\ghj 1       813653
\1      954653  xym\abvb        1       178
\1      954653  xym\aaa 1       304
\1      954653  xym\ttt 1       353
\1      954653  xym\ggg 1       98971
\1      954653  xym\ghj 1       813653
5
задан RnD 20 June 2011 в 21:30
поделиться