免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
论坛 程序设计 Shell awk
12下一页
最近访问板块 发新帖
查看: 3899 | 回复: 16
打印 上一主题 下一主题

[文本处理] awk [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-09-25 19:28 |只看该作者 |倒序浏览
大家好,我现在有这样一个以逗号“,”为分隔符的文件文件:
a,2,a11,a12,a21,a22
b,4,b11,b12,b21,b22,b31,b32,b41,b42
c,1,c11,c12
d,3,d11,d12,d21,d22,d31,d32

之后想要通过awk实现之下的输出:
a,2,a11,a12
a,2,a21,a22
b,4,b11,b12
b,4,b21,b22
b,4,b31,b32
b,4,b41,b42
c,1,c11,c12
d,3,d11,d12
d,3,d21,d22
d,3,d31,d32

不知道有没有描述清楚(有点类似于一个参数多个值,把该参数的各个值分行来描述),望多多指教,谢谢!

论坛徽章:
771
金牛座
日期:2014-02-26 17:49:58水瓶座
日期:2014-02-26 18:10:15白羊座
日期:2014-04-15 19:29:52寅虎
日期:2014-04-17 19:43:21酉鸡
日期:2014-04-19 21:24:10子鼠
日期:2014-04-22 13:55:24卯兔
日期:2014-04-22 14:20:58亥猪
日期:2014-04-22 16:13:09狮子座
日期:2014-05-05 22:31:17摩羯座
日期:2014-05-06 10:32:53处女座
日期:2014-05-12 09:23:11子鼠
日期:2014-05-21 18:21:27
2 [报告]
发表于 2014-09-25 19:43 |只看该作者
回复 1# biobaby

今天脑子迟钝了,写个awk吧.
  1. awk 'BEGIN{FS=OFS=","} {for(i=3;i<=NF;i+=2)print $1,$2,$i,$(i+1)}' i
  2. a,2,a11,a12
  3. a,2,a21,a22
  4. b,4,b11,b12
  5. b,4,b21,b22
  6. b,4,b31,b32
  7. b,4,b41,b42
  8. c,1,c11,c12
  9. d,3,d11,d12
  10. d,3,d21,d22
  11. d,3,d31,d32
复制代码

论坛徽章:
1
处女座
日期:2014-09-18 16:18:00
3 [报告]
发表于 2014-09-25 19:52 |只看该作者
回复 2# Herowinter
Hero老师瞧不起awk

   

论坛徽章:
0
4 [报告]
发表于 2014-09-25 19:53 |只看该作者
  1. # awk -F, '{s=$1","$2;for (i=1;i<NF/2;i++){print s","$(i*2+1)","$(i*2+2);}}' a
  2. a,2,a11,a12
  3. a,2,a21,a22
  4. b,4,b11,b12
  5. b,4,b21,b22
  6. b,4,b31,b32
  7. b,4,b41,b42
  8. c,1,c11,c12
  9. d,3,d11,d12
  10. d,3,d21,d22
  11. d,3,d31,d32
复制代码

论坛徽章:
771
金牛座
日期:2014-02-26 17:49:58水瓶座
日期:2014-02-26 18:10:15白羊座
日期:2014-04-15 19:29:52寅虎
日期:2014-04-17 19:43:21酉鸡
日期:2014-04-19 21:24:10子鼠
日期:2014-04-22 13:55:24卯兔
日期:2014-04-22 14:20:58亥猪
日期:2014-04-22 16:13:09狮子座
日期:2014-05-05 22:31:17摩羯座
日期:2014-05-06 10:32:53处女座
日期:2014-05-12 09:23:11子鼠
日期:2014-05-21 18:21:27
5 [报告]
发表于 2014-09-25 20:06 |只看该作者
回复 3# Kasiotao

我想写sed的,现在脑子不大好使,写不出来.
   

论坛徽章:
9
2015亚冠之大阪钢巴
日期:2015-06-04 11:47:30丑牛
日期:2015-01-22 15:49:26巳蛇
日期:2015-01-22 10:11:18巨蟹座
日期:2014-11-20 10:55:03天蝎座
日期:2014-11-16 22:10:26处女座
日期:2014-11-16 11:01:10申猴
日期:2014-09-19 11:12:37双鱼座
日期:2014-07-25 10:09:54程序设计版块每日发帖之星
日期:2015-08-24 06:20:00
6 [报告]
发表于 2014-09-25 20:40 |只看该作者
本帖最后由 Buring__ 于 2014-09-25 20:41 编辑

凑个热闹吧
没有两位老师的思路好
  1. awk -F, '{for(i=4;i<=NF;i+=2)printf $1FS$2FS$(i-1)FS$i"\n"}' urfile
复制代码

论坛徽章:
32
处女座
日期:2013-11-20 23:41:20双子座
日期:2014-06-11 17:20:43戌狗
日期:2014-06-16 11:05:00处女座
日期:2014-07-22 17:30:47狮子座
日期:2014-07-28 15:38:17金牛座
日期:2014-08-05 16:34:01亥猪
日期:2014-08-18 13:34:25白羊座
日期:2014-09-02 15:03:55金牛座
日期:2014-11-10 10:23:58处女座
日期:2014-12-02 09:17:52程序设计版块每日发帖之星
日期:2015-06-16 22:20:002015亚冠之塔什干火车头
日期:2015-06-20 23:28:22
7 [报告]
发表于 2014-09-25 20:49 |只看该作者
来个稍微短点的吧~{:3_193:}
  1. awk 'BEGIN{FS=OFS=","}{for(i=2;i++<NF;)print $1,$2,$i,$(++i)}'
复制代码

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
8 [报告]
发表于 2014-09-25 21:35 |只看该作者
回复 1# biobaby
  1. echo 'a,2,a11,a12,a21,a22
  2. b,4,b11,b12,b21,b22,b31,b32,b41,b42
  3. c,1,c11,c12
  4. d,3,d11,d12,d21,d22,d31,d32' |sed -rn 's/([^,]+,[^,]+)(,[^,]+,[^,]+)(,.+)/\1\2\n\1\3/;P;D'
  5. a,2,a11,a12
  6. a,2,a21,a22
  7. b,4,b11,b12
  8. b,4,b21,b22
  9. b,4,b31,b32
  10. b,4,b41,b42
  11. c,1,c11,c12
  12. d,3,d11,d12
  13. d,3,d21,d22
  14. d,3,d31,d32
复制代码

论坛徽章:
2
处女座
日期:2014-10-24 11:12:372015年辞旧岁徽章
日期:2015-03-03 16:54:15
9 [报告]
发表于 2014-09-25 21:54 |只看该作者
高手人,学习了……

论坛徽章:
0
10 [报告]
发表于 2014-09-25 22:05 |只看该作者
来一个,好像思路差不多,哈哈
  1. awk -F "," '{for(i=3;i<=NF;i+=2){print $1,$2,$i,$(i+1)}}' test.txt
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP