shell 或 python 脚本将行转置为列

shell 或 python 脚本将行转置为列

我有一个大文件,其中包含以下数字:

 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

相关内容