一尘不染

如何将列的数据传输到行(使用awk)?

linux

我有一个像这样的文件:

n A B C D 
1 01 02 01 01
2 02 02 01 01

而且我想按行转移列,因此输出应如下所示:

n 1 2
A 01 02
B 02 02
C 01 01 
D 01 01

我写了这个命令:

awk '{ for (i=1;i<=NF;i++ ) printf $i " " }' file.txt > out-file.txt

问题是此命令将所有内容都放在一行上!所以输出是这样的:

n 1 2 A 01 02 B 02 02 C 01 01 D 01 01

阅读 283

收藏
2020-06-03

共1个答案

一尘不染

这可能起作用:

awk '{
       for (f = 1; f <= NF; f++) { a[NR, f] = $f } 
     }
     NF > nf { nf = NF }
     END {
       for (f = 1; f <= nf; f++) {
           for (r = 1; r <= NR; r++) {
               printf a[r, f] (r==NR ? RS : FS)
           }
       }
    }' YOURINPUT

在Ideone上观看它。

2020-06-03