博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用sed做特殊的行列转换
阅读量:2445 次
发布时间:2019-05-10

本文共 2419 字,大约阅读时间需要 8 分钟。

行列转换在数据库,开发语言中都是一个津津乐道的话题,今天来简单演示一个使用sed所作的特殊行列转换。
日志的内容如下:
append data from MIG_TEST.MO1_MEMO_EXT_2 to MIG_TEST.MO1_MEMO
1936470 rows created.
Elapsed: 00:01:01.53
Commit complete.
Elapsed: 00:00:00.03
append data from MIG_TEST.MO1_MEMO_EXT_3 to MIG_TEST.MO1_MEMO
873897 rows created.
Elapsed: 00:00:22.67
Commit complete.
Elapsed: 00:00:00.02
append data from MIG_TEST.MO1_MEMO_EXT_4 to MIG_TEST.MO1_MEMO
1702297 rows created.
Elapsed: 00:00:57.67
Commit complete.
Elapsed: 00:00:00.04
append data from MIG_TEST.MO1_MEMO_EXT_5 to MIG_TEST.MO1_MEMO
1280364 rows created.
Elapsed: 00:00:52.77
现在想把特定的一些行转列,实现类似如下的效果。 这样数据条数,插入时间等就一目了然了,可以在此基础上成为报告,便于查看状态和监控。
append data from MIG_TEST.MO1_MEMO_EXT_1 to MIG_TEST.MO1_MEMO 1661924 rows created. Elapsed: 00:01:05.55
append data from MIG_TEST.MO1_MEMO_EXT_2 to MIG_TEST.MO1_MEMO 1936470 rows created. Elapsed: 00:01:01.53
append data from MIG_TEST.MO1_MEMO_EXT_3 to MIG_TEST.MO1_MEMO 873897 rows created. Elapsed: 00:00:22.67
这个时候可以使用sed来做处理,完成特定的行列转换。
首先删除多余的空行
 sed -e '/^$/d'   append_details.log
然后在此基础上根据” append data from“来做第一次行列转换。
sed  '/append data from/{N;N; s/\n/ /}'
这样,格式化后的内容就类似下面的形式。
append data from MIG_TEST.MO1_MEMO_EXT_11 to MIG_TEST.MO1_MEMO 2083618 rows created.
Elapsed: 00:01:24.92
Commit complete.
Elapsed: 00:00:00.08
append data from MIG_TEST.MO1_MEMO_EXT_12 to MIG_TEST.MO1_MEMO 976772 rows created.
Elapsed: 00:00:32.67
Commit complete.
Elapsed: 00:00:00.05
append data from MIG_TEST.MO1_MEMO_EXT_13 to MIG_TEST.MO1_MEMO 851574 rows created.
Elapsed: 00:00:30.06
Commit complete.
Elapsed: 00:00:00.02
然后再做一次行列转换,按照关键字“rows created" 来做行列转换
最后的输入类似下面。
append data from MIG_TEST.MO1_MEMO_EXT_1 to MIG_TEST.MO1_MEMO 1661924 rows created. Elapsed: 00:01:05.55
append data from MIG_TEST.MO1_MEMO_EXT_2 to MIG_TEST.MO1_MEMO 1936470 rows created. Elapsed: 00:01:01.53
append data from MIG_TEST.MO1_MEMO_EXT_3 to MIG_TEST.MO1_MEMO 873897 rows created. Elapsed: 00:00:22.67
append data from MIG_TEST.MO1_MEMO_EXT_4 to MIG_TEST.MO1_MEMO 1702297 rows created. Elapsed: 00:00:57.67
append data from MIG_TEST.MO1_MEMO_EXT_5 to MIG_TEST.MO1_MEMO 1280364 rows created. Elapsed: 00:00:52.77
完整的命令如下:
 sed -e '/^$/d'   append_details.log|sed  '/append data from/{N;N; s/\n/ /}' |sed '/rows created/{N;s/\n/ / }'|grep 'append'

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/23718752/viewspace-1224141/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/23718752/viewspace-1224141/

你可能感兴趣的文章
找到丢失的磁贴跟踪器后如何获取通知
查看>>
PlayStation 4 Pro上的“升压模式”是什么?
查看>>
android 更改软键盘_如何在Android上更改Google键盘的主题
查看>>
kodi 缓存文件夹_如何将Kodi图稿与视频存储在同一文件夹中
查看>>
windows隐藏磁盘_如何在Windows的磁盘清理工具中启用隐藏选项
查看>>
如何在Linux或macOS终端中使用Bash历史记录
查看>>
photos设置成中文_如何在OS X的Photos中设置和使用扩展程序
查看>>
大剧院自助签证_如果您的项目是《剧院》,请使用演员
查看>>
qnx 开发十步_十步实现应用程序本地化
查看>>
ML.NET模型构建器更新
查看>>
windows终端终端_Windows终端介绍
查看>>
小额免密_如何在您的应用中进行小额付款
查看>>
用开源代码如何建立网站_建立全球开源法律网络
查看>>
c&c++语言参考手册_C ++值类别快速参考:第2部分
查看>>
javascript优化_优化性能的十大JavaScript技巧
查看>>
ruby on rails_Ruby on Rails在市场开发中的重要地位
查看>>
react 编程式路由_如何做React式编程。 第2部分:副作用
查看>>
传统网络面临问题_我们每天都面临的最流行的计算机问题
查看>>
aws cmake .._如何将Hyperledger Fabric 1.4部署到AWS
查看>>
机器人学数学理论_基于格理论的机器学习数学
查看>>