Awk-сравните 2 файла с помощью нескольких столбцов и распечатайте строки из обоих файлов

Таким образом, у меня есть два плоские файлы, который находится в формате следующим образом

File1.txt

Customer1 12345 12346 12347 15646
Customer2 14444 14445

File2.txt

12345 aol.com
12347 gmail.com
12346 google.com
14444 yahoo.com
14445 outlook.com
15646 space.com

Мой вывод Требования был бы:

Customer1 aol.com gmail.com google.com space.com
Customer2 yahoo.com outlook.com

Я имею, придумал следующее до сих пор, но это только, кажется, использует столбец 2 из файла 1, есть ли этого, я могу развернуть эту команду для включения всех столбцов в файле 1?

awk 'NR==FNR {a[$1]=$2; next} $2 in a {print $0, a[$2]}' OFS='\' file2.txt file1.txt
1
задан 21 June 2019 в 19:14

1 ответ

Вам нужно будет обойти поля $2 и далее в File1.txt:

$ awk 'NR==FNR {a[$1]=$2; next} {for (i=2;i<=NF;i++) $i = $i in a ? a[$i] : $i} 1' File2.txt File1.txt
Customer1 aol.com google.com gmail.com space.com
Customer2 yahoo.com outlook.com

$i = $i in a ? a[$i] : $i можно упростить до $i = a[$i], если вы уверены, что будет совпадение или если вы хотите заменить несоответствия пустыми полями.

1
ответ дан 21 June 2019 в 19:14

Другие вопросы по тегам:

Похожие вопросы: