免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 11526 | 回复: 14

列转行的需求 [复制链接]

论坛徽章:
0
发表于 2011-03-07 12:03 |显示全部楼层
name 121212
age 12

name  232323
age 23

转换成

name      age
121212   12
232323   23

请问shell 如何实现?

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
发表于 2011-03-07 12:08 |显示全部楼层
  1. awk 'BEGIN{print "name\tage"}/name/{v=$2}/age/{print v FS $2}' FILE
  2. name    age
  3. 121212 12
  4. 232323 23
复制代码

论坛徽章:
0
发表于 2011-03-07 12:23 |显示全部楼层
name  和 age 可以用变量的方式取得吗?

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
发表于 2011-03-07 12:37 |显示全部楼层
name  和 age 可以用变量的方式取得吗?
5iwww 发表于 2011-03-07 12:23



    没有问题,但规则是?
  每条记录之间都是用空行分割开的?

论坛徽章:
0
发表于 2011-03-07 13:37 |显示全部楼层
本帖最后由 5iwww 于 2011-03-07 13:41 编辑

恩 是的  因为 我可能面临的表是很多字段的 想遍历第一列为表头 第二列为数据

但是现在没想好第2列 如何用空行作为隔断。。。。

举个例子

txt是这样的

name  121
age     212
ip        192.168.1.2
pass    $%#$%^$&$^$
(空行)
name  123
age     213
ip        192.168.1.3
pass    $%#$%^$&$^$56
......以此类推

输出像这样

name   age    ip                   pass
121      212   192.168.1.2   $%#$%^$&$^$
123      213   192.168.1.3   $%#$%^$&$^$56
.............以此类推

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
发表于 2011-03-07 13:57 |显示全部楼层
本帖最后由 yinyuemi 于 2011-03-07 14:42 编辑
恩 是的  因为 我可能面临的表是很多字段的 想遍历第一列为表头 第二列为数据

但是现在没想好第2列 如何 ...
5iwww 发表于 2011-03-07 13:37



    这样么?
  1. awk 'BEGIN{print "name\tage\tip\tpass"}/name/{name=$2}/age/{age=$2}/ip/{ip=$2}/pass/{print name,age,ip,$2}' OFS="\t"  file |while read name age ip pass
  2. do
  3. echo $name $age $ip $pass
  4. done
  5. name age ip pass
  6. 121 212 192.168.1.2 $%#$%^$&$^$
  7. 123 213 192.168.1.3 $%#$%^$&$^$56
复制代码

论坛徽章:
0
发表于 2011-03-07 14:45 |显示全部楼层
  1. awk 'BEGIN{RS="name";print "name\tage\tip\tpass"}{print $1"\t"$3"\t"$5"\t"$7}' file
复制代码
献丑了~~

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亚洲杯之朝鲜
日期:2015-03-13 22:47:33IT运维版块每日发帖之星
日期:2016-01-09 06:20:00IT运维版块每周发帖之星
日期:2016-03-07 16:27:44
发表于 2011-03-07 15:42 |显示全部楼层
try
  1. awk -v RS= 'NR==1{for(i=1;i<=NF;i+=2) h = h " " $i;print h}{v="";for(i=2;i<=NF;i+=2)v=v " "$i;print v}' urfile|column -t
复制代码

论坛徽章:
0
发表于 2011-03-07 15:53 |显示全部楼层
越写越精彩 多谢LS各位

论坛徽章:
0
发表于 2011-03-07 18:08 |显示全部楼层
本帖最后由 seeLnd 于 2011-03-07 18:25 编辑

挺有意思的,我也来一个:
  1. awk 'NF!=0{a[$1]=a[$1]"\n"$2}END{for(i in a){print i""a[i] >i;n=n" "i}print "paste "n";rm -f "n}' file | sh
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP