2つのファイルがあります。
f1: f2:
============== ===============
some text line 1 A1
some text line 2 A2
some text line 3 A3
これら2つのファイルをすばやくマージしてf3を作成できます。
some text line 1
A1
some text line 2
A2
some text line 3
A3
答え1
これは仕事ですpaste
:
paste -d'\n' f1.txt f2.txt
例:
$ cat foo.txt
some text line 1
some text line 2
some text line 3
$ cat bar.txt
A1
A2
A3
$ paste -d'\n' foo.txt bar.txt
some text line 1
A1
some text line 2
A2
some text line 3
A3
答え2
はい、whileループを使用してこれを行いますread
。
#!/bin/sh
while read file1 <&3 && read file2 <&4
do
printf "%s\n" "$file1" >> mergedFile.txt
printf "%s\n" "$file2" >> mergedFile.txt
done 3</path/to/file1/file1.txt 4</path/to/file2/file2.txt
echo
代わりに、mergedFile.txtで.resultを使用できますprintf
。処理中のファイルがそれほど大きくない場合、上記のアプローチはほとんどのソリューションよりも簡単で移植性があります。
答え3
POSIX awk;これは複数のファイルで機能し、ファイルの行数が同じである必要はありません。すべてのファイルが行数を超えるまで、スクリプトは実行を続けます。
BEGIN {
do {
br = ch = 0
while (++ch < ARGC)
if (getline < ARGV[ch]) {
print
br = 1
}
} while (br)
}