免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4366 | 回复: 9
打印 上一主题 下一主题

awk 怎么把一列变成多列? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-05-10 14:39 |只看该作者 |倒序浏览
比如我有一列:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
我想分成三列显示:
1       6         11
2       7         12
3       8         13
4       9         14
5       10
该如何做?
谢谢!

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
2 [报告]
发表于 2009-05-10 14:55 |只看该作者


  1. awk 'BEGIN{x=0;}{a[x++]=$0}END{y=int((x+2)/3);for(i=0;i<y;i++)print a[i],a[i+y],a[i+2*y]}'
复制代码

论坛徽章:
0
3 [报告]
发表于 2009-05-10 15:16 |只看该作者
ok!
十分感谢!数组应用的很棒!

论坛徽章:
0
4 [报告]
发表于 2009-05-10 15:22 |只看该作者
cat file|paste - - -

论坛徽章:
0
5 [报告]
发表于 2009-05-10 15:25 |只看该作者

回复 #2 cjaizss 的帖子

请教版主:
如我现在的文件hh:
1 12 浏
2 13 luiliu 发大水放掉
1 12 浏
1 12 浏
1 12 浏
1 12 浏
1 12 浏
2 13 luiliu 发大水放掉
2 13 luiliu 发大水放掉
2 13 luiliu 发大水放掉
1 12 浏
1 12 浏
1 12 浏
2 13 luiliu 发大水放掉
2 13 luiliu 发大水放掉
2 13 luiliu 发大放掉
2 13 luiliu 发大水放掉
2 13 luiliu 发大放掉
2 13 luiliu 发大放掉
2 13 luiliu 发大放掉
2 13 luiliu 发大水放掉
2 13 luiliu 发大水放掉
2 13 luiliu 发大放掉
2 13 luiliu 发大水放掉
2 13 luiliu 发大
cat hh|1 12 浏
2 13 luiliu 发大水放掉
1 12 浏
1 12 浏
1 12 浏
1 12 浏
1 12 浏
2 13 luiliu 发大水放掉
2 13 luiliu 发大水放掉
2 13 luiliu 发大水放掉
1 12 浏
1 12 浏
1 12 浏
2 13 luiliu 发大水放掉
2 13 luiliu 发大水放掉
2 13 luiliu 发大放掉
2 13 luiliu 发大水放掉
2 13 luiliu 发大放掉
2 13 luiliu 发大放掉
2 13 luiliu 发大放掉
2 13 luiliu 发大水放掉
2 13 luiliu 发大水放掉
2 13 luiliu 发大放掉
2 13 luiliu 发大水放掉
2 13 luiliu 发大
1 12 浏
2 13 luiliu 发大水放掉
1 12 浏
1 12 浏
1 12 浏
1 12 浏
1 12 浏
2 13 luiliu 发大水放掉
2 13 luiliu 发大水放掉
2 13 luiliu 发大水放掉
1 12 浏
1 12 浏
1 12 浏
2 13 luiliu 发大水放掉
2 13 luiliu 发大水放掉
2 13 luiliu 发大放掉
2 13 luiliu 发大水放掉
2 13 luiliu 发大放掉
2 13 luiliu 发大放掉
2 13 luiliu 发大放掉
2 13 luiliu 发大水放掉
2 13 luiliu 发大水放掉
2 13 luiliu 发大放掉
2 13 luiliu 发大水放掉
2 13 luiliu 发大
cat hh|awk 'BEGIN{x=0;}{a[x++]=$0}END{y=int((x+2)/3);for(i=0;i<y;i++)print a"\t\t"a[i+y]"\t\t"a[i+2*y]}'后就成了:
1 12 浏                2 13 luiliu 发大水放掉                2 13 luiliu 发大放掉
2 13 luiliu 发大水放掉                1 12 浏                2 13 luiliu 发大放掉
1 12 浏                1 12 浏                2 13 luiliu 发大水放掉
1 12 浏                1 12 浏                2 13 luiliu 发大水放掉
1 12 浏                2 13 luiliu 发大水放掉                2 13 luiliu 发大放掉
1 12 浏                2 13 luiliu 发大水放掉                2 13 luiliu 发大水放掉
1 12 浏                2 13 luiliu 发大放掉                2 13 luiliu 发大
2 13 luiliu 发大水放掉                2 13 luiliu 发大水放掉               
2 13 luiliu 发大水放掉                2 13 luiliu 发大放掉       
怎么才能让他们排列的更条理一些?
谢谢!

论坛徽章:
0
6 [报告]
发表于 2009-05-10 16:26 |只看该作者
print换成printf格式化一下就行了。
printf("%-30s\t%-30s\t%-30s\n",a,a[i+y],a[i+2*y])

论坛徽章:
0
7 [报告]
发表于 2009-05-10 18:45 |只看该作者
xargs -n3 < ufile
1 2 3
4 5 6
7 8 9
0



xargs -n3 < ufile | awk '{printf "%-20s%-20s%-20s\n",$1,$2,$3}'

论坛徽章:
0
8 [报告]
发表于 2009-05-10 22:52 |只看该作者
justlook和steel_lei都太急着给答案了~

论坛徽章:
0
9 [报告]
发表于 2009-05-11 15:22 |只看该作者
问题已解决,十分感谢!

论坛徽章:
0
10 [报告]
发表于 2009-05-11 22:06 |只看该作者

回复 #8 kwokcn 的帖子

我一看到斜体的字就容易晕。。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP