2つのファイルの単語をそのまま追加する方法[重複]

2つのファイルの単語をそのまま追加する方法[重複]

1行あたりの単語数と列フィールド数が同じ2つのファイルがあります。これら2つのファイルをそのまま追加したいと思います。たとえば、

ファイル1:

A1 B1 C1
D1 E1 B1 C1

ファイル2:

A2 B2 C2
D2 E2 B2 C2

出力は次のようになります(単語数を考慮する必要があります)。

A1_A2 B1_B2 C1_C2 
D1_D2 E1_E2 B1_B2 C1_C2

ベストアンサー1

これアッ解決策:

awk '{
    getline a <"file2"
    split(a,A)
    for(i=1;i<=NF;i++)
        printf("%s_%s ", $i, A[i])
    print ""
    }' file1

生地+sed:

paste file1 file2 | 
sed '
    :a
    s/\(\(^\|\s\)[^_[:blank:]]\+\b\)\s*\(.*\t\)\(\S\+\)\s*/\1_\4 \3/
    ta
    s/\s*$//
    '

バッシュループ:

exec 3<file1 4<file2
while read -u 3 a ; read -u 4 b 
do 
    echo $(paste -d_ <(printf '%s\n' $a) <(printf '%s\n' $b))
done

おすすめ記事