我有一个大文件,其中包含以下数字:
1 2 3 4
5 6 7 8
9 9 9 9
我想把它转变成
1 5 9
2 6 9
3 7 9
4 8 9
我在谷歌上搜索解决方案,但这些解决方案根本不适用于我的情况。
答案1
这个解决方案应该适合你。
awk '
{
for (i=1; i<=NF; i++) {
a[NR,i] = $i
}
}
NF>p { p = NF }
END {
for(j=1; j<=p; j++) {
str=a[1,j]
for(i=2; i<=NR; i++){
str=str" "a[i,j];
}
print str
}
}' file
测试
cat file
1 2 3 4
5 6 7 8
9 0 1 11
运行上述命令后,输出为:
1 5 9
2 6 0
3 7 1
4 8 11
参考
https://stackoverflow.com/questions/1729824/transpose-a-file-in-bash
答案2
如果你可以使用perl
:
$ perl -anle '
$l[$_] .= $F[$_] for 0..$#F;
END {
print join " ", split // for @l;
}' file
1 5 9
2 6 9
3 7 9
4 8 9
或使用unpack
:
$ perl -nle '
$i = 0;
$l[$i++] .= $_ for unpack "(A2)*";
END {
print join " ", split // for @l;
}' file
1 5 9
2 6 9
3 7 9
4 8 9