如何用awk将整列的数据转换成多列

比如下面这个文件中的数据
[1]
23
56
89
[2]
78
76
65
[3]
56
34
41
[4]
19
16
67
·
·
·
转换成
[1] [2] [3] [4] ···
23 78 56 19 ···
56 76 34 16 ···
89 65 41 67 ···
因为数据文本里面的数据比较多,所以程序是可以处理大量数据的。

假设你的文件很规律,每4行一个循环:

awk '
{
if (NR % 4 == 1) {arr[1]=arr[1]" "$1} 
else if (NR % 4 == 2) { arr[2]=arr[2]" "$1}
else if (NR % 4 == 3) {arr[3]=arr[3]" "$1}
else {arr[4]=arr[4]" "$1}
}
END{
printf ("%-s\n %-s\n %-s\n %-s\n",arr[1],arr[2],arr[3],arr[4])
}' a.txt | column  -t
[1]  [2]  [3]  [4]
23   78   56   19
56   76   34   16
89   65   41   67

用递归函数也可以,不过比较复杂一些

https://zhidao.baidu.com/question/1760366755251744948.html

这行吗?

 awk '
BEGIN{OFS="\n"}
{
    if ( $1 ~ /\[/ ) {
        cnt=0
        arr[cnt]=arr[cnt]" "$1
    } else {
        cnt=cnt+1
        arr[cnt]=arr[cnt]" "$1
    }
}
END{for ( i in arr ) { print arr[i]}
}' a.txt | column -t 

适合每个[N]段落都是4行、5行、6行......一循环的情况

如果是一会4行、一会5行、一会6行的情况,我想awk实现起来会非常非常复杂。可以考虑用编程语言实现。