列转行的需求
时间:2011-03-07
来源:互联网
age 12
name 232323
age 23
转换成
name age
121212 12
232323 23
请问shell 如何实现?
作者: 5iwww 发布时间: 2011-03-07
- awk 'BEGIN{print "name\tage"}/name/{v=$2}/age/{print v FS $2}' FILE
- name age
- 121212 12
- 232323 23
作者: yinyuemi 发布时间: 2011-03-07
作者: 5iwww 发布时间: 2011-03-07
5iwww 发表于 2011-03-07 12:23
没有问题,但规则是?
每条记录之间都是用空行分割开的?
作者: cjaizss 发布时间: 2011-03-07
恩 是的 因为 我可能面临的表是很多字段的 想遍历第一列为表头 第二列为数据
但是现在没想好第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
但是现在没想好第2列 如何 ...
5iwww 发表于 2011-03-07 13:37
这样么?
- 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
- do
- echo $name $age $ip $pass
- done
- name age ip pass
- 121 212 192.168.1.2 $%#$%^$&$^$
- 123 213 192.168.1.3 $%#$%^$&$^$56
作者: yinyuemi 发布时间: 2011-03-07
- awk 'BEGIN{RS="name";print "name\tage\tip\tpass"}{print $1"\t"$3"\t"$5"\t"$7}' file
作者: wvuu 发布时间: 2011-03-07
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28