免费注册 查看新帖 |

Chinaunix

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

文本处理 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-02-18 15:07 |只看该作者 |倒序浏览
原文本
Number,AA,BB,CC,DD,EE,FF,GG
11111111,1,2,3,4,5,6,7
11111111,1,2,3,4,5,6,7

转为
Num,Name,Value
11111111,AA,1
11111111,BB,2
11111111,CC,3
11111111,DD,4
11111111,EE,5
11111111,FF,6
11111111,GG,7
11111111,AA,1
11111111,BB,2
11111111,CC,3
11111111,DD,4
11111111,EE,5
11111111,FF,6
11111111,GG,7

Number相同转格式后也不会叠加,各自分开显示的
求各位大大帮忙

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
2 [报告]
发表于 2011-02-18 15:19 |只看该作者
回复 1# chaogooler8888
  1. awk -F, 'BEGIN{print "Num,Name,Value"}
  2. NR==1{for(i=2;i<=NF;i++) a[i]=$i}NR>1{for(j=2;j<=NF;j++) print $1 FS a[j] FS $j}'
复制代码

论坛徽章:
0
3 [报告]
发表于 2011-02-18 15:23 |只看该作者
ok了
:wink:非常感谢

论坛徽章:
1
摩羯座
日期:2014-12-29 15:59:36
4 [报告]
发表于 2011-02-18 17:31 |只看该作者
perl -F, -ane 'BEGIN{print "Num,Name,Value\n"}{chomp(@F);if($.==1){@a=@F}else{for($i=1;$i<@F;$i++){print $F[0].$".$a[$i].$".$F[$i]."\n"}}}'

论坛徽章:
0
5 [报告]
发表于 2011-02-18 19:30 |只看该作者
试着用sed弄了一个,感觉比较笨,不知道有没有好点的办法。

  1. #!/bin/bash

  2. NAMES=($(head -n1 sample.txt|sed 's/,/ /g'))
  3. echo "Num,Name,Value"

  4. sed -rn "1!s/([0-9]+),([0-9]+),([0-9]+),([0-9]+),([0-9]+),([0-9]+),([0-9]+),([0-9]+)/\1,${NAMES[1]},\2\n\1,${NAMES[2]},\3\n\1,${NAMES[3]},\4\n\1,${NAMES[4]},\5\n\1,${NAMES[5]},\6\n\1,${NAMES[6]},\7\n\1,${NAMES[7]},\8\n/gp" sample.txt|sed '/^$/d'
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP