免费注册 查看新帖 |

Chinaunix

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

[数值计算] awk计算两行数据的比 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-09-27 11:34 |只看该作者 |倒序浏览
Key_read_requests                         19474458646   
Key_reads                                 2968865

我想在一条awk命令里面 计算 Key_reads 的值 2968865 / Key_read_requests 的值

上网搜了搜,木有头绪,谢谢

论坛徽章:
60
20周年集字徽章-20	
日期:2020-10-28 14:04:3015-16赛季CBA联赛之北京
日期:2016-07-06 15:42:0715-16赛季CBA联赛之同曦
日期:2016-06-12 10:38:0915-16赛季CBA联赛之佛山
日期:2016-05-27 11:54:56黄金圣斗士
日期:2015-12-02 11:44:35白银圣斗士
日期:2015-11-25 14:32:43白银圣斗士
日期:2015-11-23 12:53:352015亚冠之布里斯班狮吼
日期:2015-10-21 16:55:482015亚冠之首尔
日期:2015-09-01 16:46:052015亚冠之德黑兰石油
日期:2015-08-31 11:39:192015亚冠之萨济拖拉机
日期:2015-08-28 21:06:5315-16赛季CBA联赛之广东
日期:2016-07-12 14:58:53
2 [报告]
发表于 2014-09-27 11:43 |只看该作者
  1. awk '{a[$1]=$2}END{print a["Key_reads"]/a["Key_read_requests"]}' file
复制代码

论坛徽章:
8
技术图书徽章
日期:2013-08-22 11:21:28未羊
日期:2015-01-19 22:22:25巳蛇
日期:2014-08-11 16:53:08子鼠
日期:2014-05-29 09:04:44摩羯座
日期:2014-04-11 14:15:07丑牛
日期:2014-01-24 12:41:28金牛座
日期:2013-11-21 17:38:28射手座
日期:2015-01-21 08:50:32
3 [报告]
发表于 2014-09-27 11:44 |只看该作者
只有两行,就一口气读完它,存进变量,然后END的时候输出结果就好~

如果不只两行,就弄两个关联数组(key是递增的数字+关键词),END的是循环数字遍历元素后输出结果

论坛徽章:
14
15-16赛季CBA联赛之辽宁
日期:2019-06-16 15:47:3515-16赛季CBA联赛之广夏
日期:2016-08-13 21:24:352015亚冠之武里南联
日期:2015-07-07 17:37:372015亚冠之萨济拖拉机
日期:2015-07-06 17:07:482015亚冠之全北现代
日期:2015-06-04 13:54:272015亚冠之城南
日期:2015-05-21 15:43:212015年亚洲杯之伊朗
日期:2015-04-25 18:20:362015年亚洲杯之伊朗
日期:2015-04-20 16:06:052015年亚洲杯之科威特
日期:2015-03-07 12:51:26丑牛
日期:2014-12-30 10:26:38申猴
日期:2014-09-28 22:40:18金牛座
日期:2014-09-13 21:12:22
4 [报告]
发表于 2014-09-27 11:47 |只看该作者
本帖最后由 reb00t 于 2014-09-27 11:49 编辑
  1. awk '/Key_read_requests/{k=$2}/Key_reads/{v=$2}k&&v{print v/k;k=v=""}' 1
  2. 结果
  3. 0.000152449
复制代码
比较省内存!

论坛徽章:
1
处女座
日期:2014-09-18 16:18:00
5 [报告]
发表于 2014-09-27 11:47 |只看该作者
回复 1# 513964839
不知道你文件是什么格式的。。。如果是类似。。。
  1. Key_read_requests                         19474458646        
  2. Key_reads                                 2968865
  3. Key_read_requests                         19474458646        
  4. Key_reads                                 2968865
  5. Key_read_requests                         19474458646        
  6. Key_reads                                 2968865
  7. Key_read_requests                         19474458646        
  8. Key_reads                                 2968865
复制代码
  1. awk '{a[NR]=$1;b[NR]=$2;if(NR%2==0){print a[NR-1]"/"a[NR]"="b[NR]/b[NR-1]}}' testfile
复制代码

论坛徽章:
0
6 [报告]
发表于 2014-09-27 12:32 |只看该作者
回复 2# reyleon


    感谢,要的就是这个。


awk,sed 命令得这么学啊。。。现在主要是平时用到才会去找找,怎么可以系统的学学呀

论坛徽章:
0
7 [报告]
发表于 2014-09-27 12:33 |只看该作者
回复 5# Kasiotao


    谢谢

论坛徽章:
0
8 [报告]
发表于 2014-09-27 23:14 |只看该作者
推荐你一本书: UNIX.shell范例精解
回复 6# 513964839


   

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:58:11
9 [报告]
发表于 2014-09-28 13:25 |只看该作者
回复 4# reb00t


几个问题:

awk 怎么申请内存的
awk 怎么释放内存的

数组在内存中怎么存放

字符串在内存中怎么存放的

一个 整形 在内存中占有多少字节

栈和堆 有是怎么处理的

还有利用了 正则匹配,这个过程是怎么申请内存的

时间复杂度 和空间复杂度 是怎么回事,怎么平衡


论坛徽章:
14
15-16赛季CBA联赛之辽宁
日期:2019-06-16 15:47:3515-16赛季CBA联赛之广夏
日期:2016-08-13 21:24:352015亚冠之武里南联
日期:2015-07-07 17:37:372015亚冠之萨济拖拉机
日期:2015-07-06 17:07:482015亚冠之全北现代
日期:2015-06-04 13:54:272015亚冠之城南
日期:2015-05-21 15:43:212015年亚洲杯之伊朗
日期:2015-04-25 18:20:362015年亚洲杯之伊朗
日期:2015-04-20 16:06:052015年亚洲杯之科威特
日期:2015-03-07 12:51:26丑牛
日期:2014-12-30 10:26:38申猴
日期:2014-09-28 22:40:18金牛座
日期:2014-09-13 21:12:22
10 [报告]
发表于 2014-09-28 13:34 |只看该作者
回复 9# 这个冬天不冷


    我一直都菜鸟,在论坛学习。

既然能提出问题来,你肯定知道,请给菜鸟们科普下吧~
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP