+ -
当前位置:首页 → 问答吧 → 列转行的需求

列转行的需求

时间:2011-03-07

来源:互联网

name 121212
age 12

name  232323
age 23

转换成

name      age
121212   12
232323   23

请问shell 如何实现?

作者: 5iwww   发布时间: 2011-03-07

  1. awk 'BEGIN{print "name\tage"}/name/{v=$2}/age/{print v FS $2}' FILE
  2. name    age
  3. 121212 12
  4. 232323 23
复制代码

作者: yinyuemi   发布时间: 2011-03-07

name  和 age 可以用变量的方式取得吗?

作者: 5iwww   发布时间: 2011-03-07



QUOTE:
name  和 age 可以用变量的方式取得吗?
5iwww 发表于 2011-03-07 12:23




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

作者: cjaizss   发布时间: 2011-03-07

本帖最后由 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
.............以此类推

作者: 5iwww   发布时间: 2011-03-07

本帖最后由 yinyuemi 于 2011-03-07 14:42 编辑


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

但是现在没想好第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
复制代码

作者: yinyuemi   发布时间: 2011-03-07

  1. awk 'BEGIN{RS="name";print "name\tage\tip\tpass"}{print $1"\t"$3"\t"$5"\t"$7}' file
复制代码
献丑了~~

作者: wvuu   发布时间: 2011-03-07