比如下面这个文件中的数据
[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 ···
因为数据文本里面的数据比较多,所以程序是可以处理大量数据的。
如何用awk将整列的数据转换成多列
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
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
用递归函数也可以,不过比较复杂一些
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 x趋于0时tanx-sinx极限可以拆开算吗
- ¥500 把面具戴到人脸上,请大家贡献智慧
- ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。
- ¥15 各位 帮我看看如何写代码,打出来的图形要和如下图呈现的一样,急
- ¥30 c#打开word开启修订并实时显示批注
- ¥15 如何解决ldsc的这条报错/index error
- ¥15 VS2022+WDK驱动开发环境
- ¥30 关于#java#的问题,请各位专家解答!
- ¥30 vue+element根据数据循环生成多个table,如何实现最后一列 平均分合并
- ¥20 pcf8563时钟芯片不启振