免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 2916 | 回复: 12
打印 上一主题 下一主题

请教SED 合并行的操作 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-03-15 16:07 |只看该作者 |倒序浏览
本帖最后由 xiaoyang8791 于 2012-03-15 16:08 编辑

2012-03-15 11:16:59,072 DEBUG    EMPJDBC - [ThreadId:113381] Procedure[PB_LOG_WRITE_COMMON_LOG]'s input paramaters:
logCustomerId = 1000008924
logBusinessCode = PB0000
logErrorMessage = 交易成功
Procedure[PB_LOG_WRITE_COMMON_LOG]'s output paramaters:
2012-03-15 11:18:59,072 DEBUG    EMPJDBC - [ThreadId:113344] Procedure[PB_LOG_WRITE_COMMON_LOG]'s input paramaters:
logCustomerId = 1000008940
logBusinessCode = PB0000
logErrorMessage = 交易成功
Procedure[PB_LOG_WRITE_COMMON_LOG]'s output paramaters:


能够实现将如上的日志使用SED合并变成两行,方便我使用Syslog发出.多谢.效果如下:

2012-03-15 11:16:59,072 DEBUG    EMPJDBC - [ThreadId:113381] Procedure[PB_LOG_WRITE_COMMON_LOG]'s input paramaters:  logCustomerId = 1000008924 logBusinessCode = PB0000 logErrorMessage = 交易成功 Procedure[PB_LOG_WRITE_COMMON_LOG]'s output paramaters:
2012-03-15 11:18:59,072 DEBUG    EMPJDBC - [ThreadId:113344] Procedure[PB_LOG_WRITE_COMMON_LOG]'s input paramaters:  logCustomerId = 1000008940 logBusinessCode = PB0000 logErrorMessage = 交易成功 Procedure[PB_LOG_WRITE_COMMON_LOG]'s output paramaters:



论坛徽章:
0
2 [报告]
发表于 2012-03-15 16:18 |只看该作者
  1. sed -n ':a;/paramaters:$/{s/\n/ /g;p;b;};N;ba'
复制代码
awk的交给楼下吧

论坛徽章:
0
3 [报告]
发表于 2012-03-15 16:21 |只看该作者

  1. sed -n 'H;${x;s/.//;s/\n\([^0-9]\)/ \1/g;p;}'
复制代码

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
4 [报告]
发表于 2012-03-15 16:25 |只看该作者

  1. sed -rn ':b;/[0-9]{4}-[0-9]{2}-[0-9]{2}/{h;ba;};d;:a;${x;s/\n/ /g;p;q;};n;//!{H;ba;};x;s/\n/ /g;p;g;bb;'
复制代码

论坛徽章:
0
5 [报告]
发表于 2012-03-15 16:28 |只看该作者
  1. sed ':a N;/output/!ba;s/\n/ /g' data
复制代码

论坛徽章:
0
6 [报告]
发表于 2012-03-15 16:30 |只看该作者

  1. sed -n 'H;5~5{z;x;s/\n//gp;}'
复制代码

论坛徽章:
0
7 [报告]
发表于 2012-03-15 16:34 |只看该作者
多谢,我一个个尝试下

论坛徽章:
0
8 [报告]
发表于 2012-03-15 17:04 |只看该作者
好象还是有点问题:
[root@linuxbase tmp]# cat bank.log|sed -n ':a;/paramaters/{s/\n/ /g;p;b;};N;ba'
[root@linuxbase tmp]#

[root@linuxbase tmp]# cat bank.log|sed -n 'H;${x;s/.//;s/\n\([^0-9]\)/ \1/g;p;}'
Procedure[PB_LOG_WRITE_COMMON_LOG]'s output paramaters:381] Procedure[PB_LOG_WRITE_COMMON_LOG]'s input aramaters:
Procedure[PB_LOG_WRITE_COMMON_LOG]'s output paramaters:344] Procedure[PB_LOG_WRITE_COMMON_LOG]'s input paramaters:

论坛徽章:
0
9 [报告]
发表于 2012-03-15 17:10 |只看该作者
回复 8# xiaoyang8791

  1.     sed -n ':a;/paramaters/{s/\n/ /g;p;b;};N;ba'
复制代码
不要匹配的那么严格试下.

论坛徽章:
1
2015亚冠之吉达阿赫利
日期:2015-09-09 16:42:38
10 [报告]
发表于 2012-03-15 17:11 |只看该作者
本帖最后由 jiaogeshahaone 于 2012-03-15 17:13 编辑

awk -v RS="output paramaters:\n" '{gsub(/\n/," ",$0);print $0,RS}'
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP