免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2068 | 回复: 6

[文本处理] bash处理多行转成多列的文本 [复制链接]

论坛徽章:
1
操作系统版块每日发帖之星
日期:2016-01-20 06:20:00
发表于 2019-02-22 15:29 |显示全部楼层
大家好,本人有个需求想请大神帮忙看下,需求如下:
一个文本文件 example.txt内容如下:
name a b c
age 1 2 3

说明:
上面文件中只有两行,但有4列,每列只有一个空格分隔,现在需要使用bash命令处理这个文本,处理后的结果如下:
name age
a 1
b 2
c 3

请问用命令如何实现,多谢了~!

论坛徽章:
0
发表于 2019-02-22 15:49 |显示全部楼层
awk '{for(i=1;i<=NF;i++)a[i,NR]=$i; if(max_nf<NF) max_nf=NF; max_nr=NR} END{ for(i=1;i<=max_nf;i++){ for(j=1;j<=max_nr;j++) printf("%s ", a[i,j]); printf("\n")}}' 1.txt

name age
a 1
b 2
c 3


论坛徽章:
1
操作系统版块每日发帖之星
日期:2016-01-20 06:20:00
发表于 2019-02-22 16:05 |显示全部楼层
回复 2# csccyab

大神,请收下膝盖~!

论坛徽章:
4
15-16赛季CBA联赛之青岛
日期:2018-07-09 14:17:2815-16赛季CBA联赛之八一
日期:2018-08-06 15:30:0515-16赛季CBA联赛之广东
日期:2018-08-09 09:11:2115-16赛季CBA联赛之佛山
日期:2019-02-14 09:26:31
发表于 2019-02-22 17:01 |显示全部楼层
  1. awk '{for(i=1;i<=NF;i++){a[NR,i]=$i}}END{for(i=1;i<=NF;i++){for(x=1;x<=NR;x++){printf a[x,i] " "}print ""}}' urfile
复制代码

论坛徽章:
0
发表于 2019-02-23 14:21 |显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
25
程序设计版块每日发帖之星
日期:2016-05-03 06:20:0015-16赛季CBA联赛之八一
日期:2018-07-05 10:34:09黑曼巴
日期:2018-07-06 15:19:5015-16赛季CBA联赛之佛山
日期:2018-08-03 13:19:3315-16赛季CBA联赛之山西
日期:2018-08-07 19:46:2315-16赛季CBA联赛之广夏
日期:2018-08-08 19:31:5015-16赛季CBA联赛之青岛
日期:2018-11-26 15:21:5015-16赛季CBA联赛之上海
日期:2018-12-11 09:45:3219周年集字徽章-年
日期:2020-04-18 23:54:5215-16赛季CBA联赛之深圳
日期:2020-04-19 21:40:19黑曼巴
日期:2022-04-03 17:55:1315-16赛季CBA联赛之八一
日期:2018-07-03 16:56:46
发表于 2019-02-23 15:09 |显示全部楼层
回复 1# bobower


  1. awk '{for(i=1;i<=NF;i++){a[i]=a[i]?a[i]" "$i:$i}}END{for(i in a){print a[i]}}' example.txt
复制代码

论坛徽章:
1
操作系统版块每日发帖之星
日期:2016-01-20 06:20:00
发表于 2019-02-25 18:39 |显示全部楼层
谢谢上面各位大大,多谢了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP