免费注册 查看新帖 |

Chinaunix

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

[文本处理] 求助:top命令输出的处理 [复制链接]

论坛徽章:
2
数据库技术版块每日发帖之星
日期:2015-10-28 06:20:00数据库技术版块每日发帖之星
日期:2015-10-29 06:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-09-18 13:58 |只看该作者 |倒序浏览
大家好,在Linux下面 ,输入 top,第6列是 RES 列,我现在 想对 第6列 进行 降序排列,然后 输出到 1个 文件中。

为了排序,必须把 第6列中带 g 的 换成 *1024*1024 kb,带 m 的 换成 *1024 kb ,如 5g 换成 5*1024*1024,5m 换成 5*1024   
我的方法是 top -b -n1 | awk '{ gsub (/m/, "*1024", $6);  gsub (/g/, "*1024*1024", $6);  print $0   }'  >! top.log
问题是
1.  gsub 替换 结果得到是 字符串,没有计算 5g( 5*1024*1024 ) 和 5m( 5*1024 )  的值?
2.  如何对 第6列 进行排序?

求大侠们指导,在线等,比较急,谢谢啦。

附带:top 命令输出格式:
PID   USER  PR  NI  VIRT   RES    SHR  S  %CPU %MEM  TIME+     COMMAND                              
14795 u1    25  0   377m   33g    4428 S  0.0  1.2   1:52.72   mysqld                              
15676 u2    18  0   317m   323m   4572 S  0.0  1.0   1:59.01   mysqld                              
15194 u3    18  0   304m   3592   4416 S  0.0  0.9   1:08.78   mysqld

论坛徽章:
0
2 [报告]
发表于 2012-09-18 15:23 |只看该作者
没有必要非要化成KB吧 , 不就是看个谁大谁小么 按照顺序   这个思路行么  分成3个文件  每个文件按照G M KB 分 在这三个文件内排序,再合成一个文件行不行?

论坛徽章:
0
3 [报告]
发表于 2012-09-18 15:51 |只看该作者
回复 1# weichanghe2000

awk 'NR==1{print;next}{if($6~/g/)$6=$6*1024*1024;if($6~/m/)$6=$6*1024;print $0|"sort -k6nr "}' file
   

论坛徽章:
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
4 [报告]
发表于 2012-09-18 16:15 |只看该作者
回复 1# weichanghe2000

How about this

# top -b -n1 | awk 'NR<=7{print;next}{n=$6;if(n~/m/)n*=1024;if(n~/g/)n*=1024*1024;a[sprintf("%12d",n)]=$0"\n"a[n]}END{c=asorti(a,b);for(n=c;n>0;n--)printf("%s", a[b[n]])}'

论坛徽章:
2
数据库技术版块每日发帖之星
日期:2015-10-28 06:20:00数据库技术版块每日发帖之星
日期:2015-10-29 06:20:00
5 [报告]
发表于 2012-09-18 19:42 |只看该作者
本帖最后由 weichanghe2000 于 2012-09-18 19:44 编辑

回复 3# kk5234

非常感谢 kk5234 大侠,这种方法对于我这种新手,可以接受,在能力范围之内。


   

论坛徽章:
2
数据库技术版块每日发帖之星
日期:2015-10-28 06:20:00数据库技术版块每日发帖之星
日期:2015-10-29 06:20:00
6 [报告]
发表于 2012-09-18 19:43 |只看该作者
本帖最后由 weichanghe2000 于 2012-09-18 22:14 编辑

回复 4# jason680

感谢 jason680 大侠。呵呵,方法好复杂,怕怕,看不懂。 awk 能够用的如此高深,真是佩服,敬佩。
   

论坛徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役纪念章
日期:2022-04-24 14:33:24
7 [报告]
发表于 2012-09-18 19:57 |只看该作者
回复 6# weichanghe2000


    其实也就是数组啊、排序啊什么的,看两遍教程就懂了。

论坛徽章:
2
数据库技术版块每日发帖之星
日期:2015-10-28 06:20:00数据库技术版块每日发帖之星
日期:2015-10-29 06:20:00
8 [报告]
发表于 2012-09-19 00:07 |只看该作者
本帖最后由 weichanghe2000 于 2012-09-19 00:13 编辑

回复 3# kk5234

上面的写法有一个地方不明白:
awk 每读一条记录,然后  便执行一次 sort命令?
还是 当 awk 所有的 记录 读完后,最后才 仅仅执行 1次 sort 命令?
如果是 前者,那 sort 命令 如何来 缓存 第1条,第2条,第 NR 记录 ?也就是 sort 命令的 排序原理了。

麻烦大侠给 答疑下,谢谢啦。

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
9 [报告]
发表于 2012-09-19 02:16 |只看该作者
回复 8# weichanghe2000

  1. seq 10 |awk '{print |"sort -nr"}'
  2. seq 10 |awk '{print |"sort -nr";close("sort -nr")}'
复制代码
http://www.gnu.org/software/gawk/manual/html_node/Two_002dway-I_002fO.html#Two_002dway-I_002fO

论坛徽章:
0
10 [报告]
发表于 2012-09-19 09:49 |只看该作者
回复 8# weichanghe2000
print $0可能反复执行多次,其输出结果先暂存于pipe中,等到该程序结束时才会执行"sort -k6nr "。
不论print $0被执行几次,"sort -k6nr "只在awk程序结束时执行1次。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP