免费注册 查看新帖 |

Chinaunix

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

多行日志中匹配多个内容的平均值 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-09-09 10:01 |只看该作者 |倒序浏览
本帖最后由 kimkcn 于 2011-09-09 11:08 编辑

现在有许多日志内容如下:
exp_bdbs_grp=12 at=21  pfs_ol_suc=0 pfs_at=0 act_ubt=12 ufs_at=1 fc_suc=0 bd_at=8 fc_at=0 drmc_sct=1 arm_sct=0 ctr_suc=1 ctr_at=6
exp_bdbs_grp=12 at=35  pfs_at=0 act_ubt=12 ufs_at=3 fc_suc=0 bd_at=8 fc_at=0 drmc_sct=1 ctr_suc=1 ctr_at=2

需要匹配如下内容,每个值均是平均值:
at=xxx
ufs_at=xxx
ctr_at=xxx

现在问题是,每个字段在日中中的位置不固定,每条日志的总列数也不固定,比如at=xxx,可能在第二列,下一条日志中可能就到第10列了。

现在要如何能够在一条命令中匹配出这3个字段的平均值?

貌似grep完全实现不了,awk的话,接5楼的用法,不知道怎么操作,多谢了

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
2 [报告]
发表于 2011-09-09 10:10 |只看该作者
现在有日志内容如下:
exp_bdbs_grp=12 at=21  pfs_ol_suc=0 pfs_at=0 act_ubt=12 ufs_at=1 fc_suc=0 bd_a ...
kimkcn 发表于 2011-09-09 10:01


$ echo 'exp_bdbs_grp=12 at=21  pfs_ol_suc=0 pfs_at=0 act_ubt=12 ufs_at=1 fc_suc=0 bd_at=8 fc_at=0 drmc_sct=1 arm_sct=0 ctr_suc=1 ctr_at=6' | awk '/ at=21/&&/ufs_at=1/&&/ctr_at=6/{print $0}'
exp_bdbs_grp=12 at=21  pfs_ol_suc=0 pfs_at=0 act_ubt=12 ufs_at=1 fc_suc=0 bd_at=8 fc_at=0 drmc_sct=1 arm_sct=0 ctr_suc=1 ctr_at=6

论坛徽章:
10
天蝎座
日期:2013-09-22 22:32:23程序设计版块每日发帖之星
日期:2016-08-07 06:20:00lufei
日期:2016-06-17 17:38:40程序设计版块每日发帖之星
日期:2016-06-12 06:20:002016科比退役纪念章
日期:2016-05-31 15:47:20CU十四周年纪念徽章
日期:2016-05-27 12:24:562015年亚洲杯之阿曼
日期:2015-05-03 21:01:352015年辞旧岁徽章
日期:2015-03-03 16:54:15天蝎座
日期:2013-10-20 21:05:24程序设计版块每日发帖之星
日期:2016-08-11 06:20:00
3 [报告]
发表于 2011-09-09 10:15 |只看该作者

  1. $ echo 'exp_bdbs_grp=12 at=21  pfs_ol_suc=0 pfs_at=0 act_ubt=12 ufs_at=1 fc_suc
  2. =0 bd_at=8 fc_at=0 drmc_sct=1 arm_sct=0 ctr_suc=1 ctr_at=6' | grep -o " at=[0-9
  3. ]\+ \| ufs_at=[0-9]\+ \| ctr_at=[0-9]\+"
  4. at=21
  5. ufs_at=1
  6. ctr_at=6
复制代码

论坛徽章:
0
4 [报告]
发表于 2011-09-09 10:16 |只看该作者
试试这个
  1. grep -oP '\b(ufs_|ctr_)?at=[^ ]+\b' file
复制代码

论坛徽章:
3
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:51:162015年亚洲杯之阿曼
日期:2015-04-07 20:00:59
5 [报告]
发表于 2011-09-09 10:22 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
6 [报告]
发表于 2011-09-09 10:49 |只看该作者
4楼和5楼都太猛了,确实可以,谢谢

那接这个操作,如果想要对多行进行同样的操作,平均对每个值取多行的平均值,又该怎么操作呢?

比如第一行的a=21,b=10
第二行的a=15,b=6
我想要得到一个结果,是每个值多行的平均值,比如a的平均值,b的平均值,这个怎么操作?

貌似grep完全实现不了,awk的话,接5楼的用法,不知道怎么操作,多谢了

论坛徽章:
15
2015年辞旧岁徽章
日期:2015-03-03 16:54:15双鱼座
日期:2015-01-15 17:29:44午马
日期:2015-01-06 17:06:51子鼠
日期:2014-11-24 10:11:13寅虎
日期:2014-08-18 07:10:55酉鸡
日期:2014-04-02 12:24:51双子座
日期:2014-04-02 12:19:44天秤座
日期:2014-03-17 11:43:36亥猪
日期:2014-03-13 08:13:51未羊
日期:2014-03-11 12:42:03白羊座
日期:2013-11-20 10:15:18CU大牛徽章
日期:2013-04-17 11:48:45
7 [报告]
发表于 2011-09-09 11:29 |只看该作者
本帖最后由 rdcwayx 于 2011-09-09 11:30 编辑
4楼和5楼都太猛了,确实可以,谢谢

那接这个操作,如果想要对多行进行同样的操作,平均对每个值取多行的 ...
kimkcn 发表于 2011-09-09 10:49
  1. awk -vRS=" +" -F = '/^at=/||/^ufs_at=/||/^ctr_at=/{a[$1]+=$2;b[$1]++}END{for (i in a) print i, a[i]/b[i]}'  infile
复制代码

论坛徽章:
0
8 [报告]
发表于 2011-09-09 18:07 |只看该作者
本帖最后由 zackiehong 于 2011-09-09 18:09 编辑

来个比较笨的~~啊哦,忘记平均了
  1. awk '{for(i=1;i<=NF;i++){if(match($i,/^at=/))a+=substr($i,4);if(match($i,/^ufs_at=/))b+=substr($i,8);if(match($i,/^ctr_at=/))c+=substr($i,8)}}END{print a,b,c}' urfile
复制代码

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
9 [报告]
发表于 2011-09-10 15:37 |只看该作者
现在有许多日志内容如下:
exp_bdbs_grp=12 at=21  pfs_ol_suc=0 pfs_at=0 act_ubt=12 ufs_at=1 fc_suc=0  ...
kimkcn 发表于 2011-09-09 10:01

  1. awk 'NR==FNR&&NF==1{a[++x]=$1;next}{for(i=1;i<=NF;i++){ret=split($i,b,/=/);if(ret!=2)continue;value[b[1]]+=b[2];count[b[1]]++;}}END{for(i=1;i<=x;i++)if(count[a[i]])print a[i],value[a[i]]/count[a[i]]}'  <(echo at;echo ufs_at;echo ctr_at;) urfile
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP