我有两个文件,每行具有相同数量的单词和列字段。我想逐字附加这两个文件。例如:
文件一:
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解决方案:
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*$//
'
bash 循环:
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