免费注册 查看新帖 |

Chinaunix

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

[Linux] 数据分行 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-06-14 01:55 |只看该作者 |倒序浏览
数据如下,以制表符分隔
A 1      2      3    5    6   9  
B  2     3      4   6      7    8
C  5     5      7   5    6      9
请问大神,如何将以上数据变成
A  1 2 3
A  5 6 9
B  2 3 4
B  6 7 8
。。。。
以制表符分隔。请大神出手帮忙,在此先谢过。

论坛徽章:
0
2 [报告]
发表于 2015-06-14 11:14 来自手机 |只看该作者
在线等了~着急

论坛徽章:
0
3 [报告]
发表于 2015-06-14 11:15 来自手机 |只看该作者
在线等了~着急

论坛徽章:
39
辰龙
日期:2013-08-21 15:45:192015亚冠之广州富力
日期:2015-05-12 16:34:52亥猪
日期:2015-03-03 17:22:00申猴
日期:2015-03-03 17:21:37未羊
日期:2014-10-10 13:45:41戌狗
日期:2014-06-17 09:53:29巨蟹座
日期:2014-06-12 23:17:17双鱼座
日期:2014-06-10 12:42:44寅虎
日期:2014-06-09 12:52:172015亚冠之卡尔希纳萨夫
日期:2015-05-24 15:24:35黄金圣斗士
日期:2015-12-02 17:25:0815-16赛季CBA联赛之吉林
日期:2017-06-24 16:43:52
4 [报告]
发表于 2015-06-14 12:51 |只看该作者
本帖最后由 关阴月飞 于 2015-06-14 12:57 编辑
  1. awk '{print $1,$2,$3,$4;print $1,$5,$6,$7}' urfile
  2. awk '$5="\n"$1FS$5' urfile
复制代码

论坛徽章:
0
5 [报告]
发表于 2015-06-14 14:16 |只看该作者
回复 4# 关阴月飞
多谢大神,及时雨啊。我在想,推广到一般情况,如果一行比如有180个数字,每6个分行,这样又该如何分呢?

   

论坛徽章:
39
辰龙
日期:2013-08-21 15:45:192015亚冠之广州富力
日期:2015-05-12 16:34:52亥猪
日期:2015-03-03 17:22:00申猴
日期:2015-03-03 17:21:37未羊
日期:2014-10-10 13:45:41戌狗
日期:2014-06-17 09:53:29巨蟹座
日期:2014-06-12 23:17:17双鱼座
日期:2014-06-10 12:42:44寅虎
日期:2014-06-09 12:52:172015亚冠之卡尔希纳萨夫
日期:2015-05-24 15:24:35黄金圣斗士
日期:2015-12-02 17:25:0815-16赛季CBA联赛之吉林
日期:2017-06-24 16:43:52
6 [报告]
发表于 2015-06-14 14:36 |只看该作者
回复 5# 321wangke321


    你最好举个例子.....

论坛徽章:
0
7 [报告]
发表于 2015-06-14 14:59 |只看该作者
关阴月飞 发表于 2015-06-14 14:36
回复 5# 321wangke321

比如每行数据增多
Input
A        1        2        3        4        5        6        7        8        9        10        11        12        13        14        15        16        17        18
B        3        5        7        9        11        13        15        17        19        21        23        25        25        25        25        16        17        18
C        5        6        7        8        9        10        11        12        13        14        15        16        16        16        16        16        17        18

Output
A        1        2        3        4        5        6
A        7        8        9        10        11        12
A        13        14        15        16        17        18
B        3        5        7        9        11        13
B        15        17        19        21        23        25
B        25        25        16        17        18        25
类似于这样的,推广成一般的。


论坛徽章:
39
辰龙
日期:2013-08-21 15:45:192015亚冠之广州富力
日期:2015-05-12 16:34:52亥猪
日期:2015-03-03 17:22:00申猴
日期:2015-03-03 17:21:37未羊
日期:2014-10-10 13:45:41戌狗
日期:2014-06-17 09:53:29巨蟹座
日期:2014-06-12 23:17:17双鱼座
日期:2014-06-10 12:42:44寅虎
日期:2014-06-09 12:52:172015亚冠之卡尔希纳萨夫
日期:2015-05-24 15:24:35黄金圣斗士
日期:2015-12-02 17:25:0815-16赛季CBA联赛之吉林
日期:2017-06-24 16:43:52
8 [报告]
发表于 2015-06-14 15:05 |只看该作者
本帖最后由 关阴月飞 于 2015-06-14 15:07 编辑

回复 7# 321wangke321
如下,你可以改变n的值来改变换行规则:
awk -vn=6  '{for(i=n+2;i<=NF;i+=n)$i="\n"$1FS$i}1' urfile

论坛徽章:
20
卯兔
日期:2015-01-26 22:05:142015亚冠之萨济拖拉机
日期:2015-09-10 15:15:282015亚冠之阿尔希拉尔
日期:2015-09-25 17:37:53程序设计版块每日发帖之星
日期:2015-10-03 06:20:00程序设计版块每日发帖之星
日期:2015-12-09 06:20:00CU十四周年纪念徽章
日期:2015-12-17 09:07:15程序设计版块每日发帖之星
日期:2015-12-25 06:20:34程序设计版块每日发帖之星
日期:2015-12-25 06:20:34程序设计版块每日发帖之星
日期:2015-12-25 06:20:342015亚冠之广州富力
日期:2015-08-27 19:29:56每日论坛发贴之星
日期:2015-08-26 06:20:002015亚冠之阿尔希拉尔
日期:2015-05-18 17:26:27
9 [报告]
发表于 2015-06-14 17:38 |只看该作者
本帖最后由 songyc_2015 于 2015-06-14 18:50 编辑

回复 1# 321wangke321
  1. a=6
  2. awk -va="${a}" '{s=$1;for(i=2;i<=NF;i++)if((i-1)%a)y=y?y"\t"$i:$i;else {print s"\t"y"\t"$i;y=""}}' file
  3. sed -r 's#([^\t]+\t)(([^\t]+\t){'"${a}"'})(.*)#\1\2\n\1\4#;P;D' file
  4. sed -r ':1;s#([^\t\n]+\t)(([^\t\n]+\t){'"${a}"'})([^\n]*)$#\1\2\n\1\4#;t1' file
复制代码

论坛徽章:
13
双鱼座
日期:2013-10-23 09:30:05数据库技术版块每日发帖之星
日期:2016-04-20 06:20:00程序设计版块每日发帖之星
日期:2016-03-09 06:20:002015亚冠之塔什干火车头
日期:2015-11-02 10:07:452015亚冠之德黑兰石油
日期:2015-08-30 10:07:07数据库技术版块每日发帖之星
日期:2015-08-28 06:20:00数据库技术版块每日发帖之星
日期:2015-08-05 06:20:002015年迎新春徽章
日期:2015-03-04 09:57:09辰龙
日期:2014-12-03 14:45:52酉鸡
日期:2014-07-23 09:46:23亥猪
日期:2014-03-13 08:46:22金牛座
日期:2014-02-11 09:36:21
10 [报告]
发表于 2015-06-15 00:02 |只看该作者
  1. awk '{for(i=1;i<=NF;++i){if(i==5){ printf "\n"$1 FS;} printf $i FS; if(i==NF) printf "\n";}}' urfile
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP