nomn文件分析
#encoding=gbk
import os
import re
import math
from os import path '''
手动输入文件nmon文件路径,要截取的开始时间,结束时间
''' rootdir='E:\\pylianxi\\ceshi' #input("请输入文件路径:")
start_time="14:46" #截取的开始时间
end_time="14:56" #截取的结束时间
print(rootdir) def avg(list_a): #求平均值函数
avg_list=0.0
float_item_list=[float(i) for i in list_a]
for i in float_item_list:
if not isinstance(i,(int,float)):
print("列表中含有非数字!!")
return None if len(float_item_list)>0:
avg_list=sum(float_item_list)/len(float_item_list)
#return round(avg_list,3)
return ('%.2f'%avg_list)
else:
return None write_count=0 #记录是否是第一次生成要输出的文件aa.txt
file_names=os.listdir(rootdir) for i in file_names:
file_path=path.join(rootdir,i)
if path.isfile(file_path) and ".nmon" in i:
print(file_path)
#file_record=re.findall(r"\w+",i)[0]+re.findall(r"\d+",i)[0]
file_record=i[:6] #+i[4:6]
#file_record=re.search(r"(\w+)-(\d+)",i).group(1)+re.search(r"(\w+)-(\d+)",i).group(2)
print(file_record)
#with open(file_path,'r',encoding='gbk') as fp:
with open(file_path,'r',encoding='utf-8') as fp:
data_all=fp.readlines()
data_times={}
for j in range(len(data_all)):
if re.search(r"ZZZZ,T",data_all[j]):
#data_times.append(data_all[j].split(',')[2])
data_times[j]=data_all[j].split(',')[2]
#print(data_times)
start_row=0
end_row=max(data_times.keys()) for k,v in data_times.items():
if start_time in v:
start_row=k
print("循环中的start_row:",start_row)
break for k,v in data_times.items():
if end_time in v:
end_row=k
print("循环中的end_row:",end_row)
break print("校验前的start_row:",start_row)
if start_row==0:
print("未找到开始时间,从文件头开始") print("校验前的end_row:",end_row)
if end_row==max(data_times.keys()):
print("未找到结束时间,计算至文件结尾") performance_cpu=[]
performance_mem=[]
performance_disk_single=[]
performance_disk=[]
for n in data_all[start_row:end_row]:
if re.search(r"CPU_ALL,T.*",n):
#print(n.split(",")[5])
performance_cpu.append(100-float(n.split(",")[5]))
if re.search(r"MEM,T.*",n):
performance_mem.append((float(n.split(",")[2])-float(n.split(",")[6])-float(n.split(",")[11]))*100/float(n.split(",")[2]))
if re.search(r"DISKXFER,T.*",n):
performance_disk_single=n.split(",")[2:]
sum_disk=0.0
for nn in performance_disk_single:
sum_disk+=float(nn)
performance_disk.append(sum_disk)
#print(performance_cpu)
#print(performance_mem)
#print(performance_disk)
cpu_avg=avg(performance_cpu)
mem_avg=avg(performance_mem)
disk_avg=avg(performance_disk)
output_filename='aa.txt'
output_path=path.join(rootdir,output_filename) if write_count==0:
fp1=open(output_path,'w',encoding='gbk')
fp1.write("")
write_count+=1
fp1.close() with open(output_path,'a+',encoding='gbk') as fp2:
fp2.write(file_record+','+str(cpu_avg)+','+str(mem_avg)+','+str(disk_avg)+'\n')
nomn文件分析的更多相关文章
- linux实践之ELF文件分析
linux实践之ELF文件分析 下面开始elf文件的分析. 我们首先编写一个简单的C代码. 编译链接生成可执行文件. 首先,查看scn15elf.o文件的详细信息. 以16进制形式查看scn15elf ...
- 蓝屏 Dump文件分析方法
WinDbg使用有点麻烦,还要符号表什么的.试了下,感觉显示很乱,分析的也不够全面... 试试其他的吧!今天电脑蓝屏了,就使用其dump文件测试,如下: 1.首先,最详细的,要属Osr Online这 ...
- KEIL MDK输出map文件分析
一.文件分析流程 1.第一部分:Section Cross References 主要是各个源文件生成的模块之间相互引用的关系. stm32f10x.o(STACK) refers (Special) ...
- ecshop init.php文件分析
1. ecshop init.php文件分析 2. <?php 3. 4. /** 5. * ECSHOP 前台公用文件 6. * ===================== ...
- [转载]mysql慢日志文件分析处理
原文地址:mysql慢日志文件分析处理作者:maxyicha mysql有一个功能就是可以log下来运行的比较慢的sql语句,默认是没有这个log的,为了开启这个功能,要修改my.cnf或者在mysq ...
- 使用 Eclipse Memory Analyzer 进行堆转储文件分析
Eclipse Memory Analyzer(MAT)是著名的跨平台集成开发环境 Eclipse Galileo 版本的 33 个组成项目中之一,它是一个功能丰富的 JAVA 堆转储文件分析工具,可 ...
- Android JNI入门第三篇——jni头文件分析
一. 首先写了java文件: public class HeaderFile { private native void doVoid(); native int doShort(); native ...
- Java class文件分析工具 -- Classpy
Classpy Classpy是一个图形化的class文件分析工具,功能和javap类似,界面主要參考了Java Class Viewer: 为什么要又一次创造轮子? 写这个工具花了将近一周的时间.那 ...
- STM32固件库文件分析
STM32固件库文件分析 1.汇编编写的启动文件 startup/stm32f10x.hd.s:设置堆栈指针,设置pc指针,初始化中断向量,配置系统时钟,对用c库函数_main最后去c语言世界里. 2 ...
随机推荐
- 实现一个Promise
实现一个Promise promise特点 一个promise的当前状态只能是pending.fulfilled和rejected三种之一.状态改变只能是pending到fulfilled或者pend ...
- 【计算机视觉】Selective Search for Object Recognition论文阅读2
Selective Search for Object Recognition 是J.R.R. Uijlings发表在2012 IJCV上的一篇文章.主要介绍了选择性搜索(Selective Sear ...
- Information Cartography
作者:Dafna Shahaf 会议:ACM 2015. 研究大背景:自动化地从很大数据集中提取结构化的知识变得越来越难.在本篇文章中,我们将探索我们在文献中(25,26,27)中创立的方法来自 ...
- [转帖]18W喂不饱有必要买30W充电器吗?iPhone 11 Pro Max充电评测
18W喂不饱有必要买30W充电器吗?iPhone 11 Pro Max充电评测 https://www.cnbeta.com/articles/tech/895237.htm 改天买一个 设备玩一玩 ...
- postman带Token测试接口
首先打开postman.是这样的界面 我们的需求是这样的.实现登录之后返回token.然后请求其他接口时在header头中带上token信息. OK.接下来我们这样操作: 现在登录没有操作token. ...
- 【坑】使用IDEA创建maven的时候,提示缺少plugin-clean 等
解决方法 检查你的网络,能否访问 maven 中央仓库 : 在 IDEA 中是否对 maven 进行了配置 IDEA 默认使用的 仓库 和 配置文件,都是 .m2 下面的: 如果你自己对 maven ...
- asp.net core-15.Individual authentication 模板
在visual studio code执行dotnet new mvc --help 可以查看执行命令 visual studio code先创建一个mvc的项目 dotnet new mvc -au ...
- java 字符串处理的
@Test public void testString(){ /*字符串处理 */ String email="123456789@qq.com"; System.out.pri ...
- vscode安装
vscode是一个很好用而且开源的编辑器,支持多种编程语言,这里稍微总结一下使用,省的以后再安装时候再百度查 下载地址:https://code.visualstudio.com/,打开以后点击dow ...
- Neo4j基本使用及导入三元组
下载和安装Neo4j 安装Java JDK 下载Neo4j安装文件 创建系统环境变量 Neo4j配置 配置文档存储在conf目录下,Neo4j通过配置文件neo4j.conf控制服务器的工作.默认情况 ...