qq_39647357 2018-04-18 09:46 采纳率: 50%
浏览 2757
已采纳

如何用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 ···
因为数据文本里面的数据比较多,所以程序是可以处理大量数据的。

  • 写回答

3条回答 默认 最新

  • 骏马金龙 2018-04-18 11:38
    关注

    假设你的文件很规律,每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
    

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • 白萝卜。 2018-04-18 09:56
    关注
    评论
  • 骏马金龙 2018-04-18 13:27
    关注
     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实现起来会非常非常复杂。可以考虑用编程语言实现。

    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥50 burgers方程求逆
  • ¥15 matlab最小二乘法拟合非线性曲线提问
  • ¥15 电脑锁屏时vba运行SAP,excel数据不能复制到SAP
  • ¥50 74LS系列 74LS00 74LS04设计一个RS485电路(关键词-差分)
  • ¥30 各位help写一下代码
  • ¥15 在运行SDEdit模型下载不了
  • ¥15 求51控制l298n驱动的小车中超声波避障怎么写
  • ¥15 电脑连上WIFI却用不了
  • ¥30 MATLAB在RLC电路的固有响应和阶跃响应GUI仿真报告
  • ¥15 hyper-v出现的问题