#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文件分析的更多相关文章

  1. linux实践之ELF文件分析

    linux实践之ELF文件分析 下面开始elf文件的分析. 我们首先编写一个简单的C代码. 编译链接生成可执行文件. 首先,查看scn15elf.o文件的详细信息. 以16进制形式查看scn15elf ...

  2. 蓝屏 Dump文件分析方法

    WinDbg使用有点麻烦,还要符号表什么的.试了下,感觉显示很乱,分析的也不够全面... 试试其他的吧!今天电脑蓝屏了,就使用其dump文件测试,如下: 1.首先,最详细的,要属Osr Online这 ...

  3. KEIL MDK输出map文件分析

    一.文件分析流程 1.第一部分:Section Cross References 主要是各个源文件生成的模块之间相互引用的关系. stm32f10x.o(STACK) refers (Special) ...

  4. ecshop init.php文件分析

    1.  ecshop init.php文件分析 2.  <?php  3.   4.  /**  5.  * ECSHOP 前台公用文件  6.  * ===================== ...

  5. [转载]mysql慢日志文件分析处理

    原文地址:mysql慢日志文件分析处理作者:maxyicha mysql有一个功能就是可以log下来运行的比较慢的sql语句,默认是没有这个log的,为了开启这个功能,要修改my.cnf或者在mysq ...

  6. 使用 Eclipse Memory Analyzer 进行堆转储文件分析

    Eclipse Memory Analyzer(MAT)是著名的跨平台集成开发环境 Eclipse Galileo 版本的 33 个组成项目中之一,它是一个功能丰富的 JAVA 堆转储文件分析工具,可 ...

  7. Android JNI入门第三篇——jni头文件分析

    一. 首先写了java文件: public class HeaderFile { private native void  doVoid(); native int doShort(); native ...

  8. Java class文件分析工具 -- Classpy

    Classpy Classpy是一个图形化的class文件分析工具,功能和javap类似,界面主要參考了Java Class Viewer: 为什么要又一次创造轮子? 写这个工具花了将近一周的时间.那 ...

  9. STM32固件库文件分析

    STM32固件库文件分析 1.汇编编写的启动文件 startup/stm32f10x.hd.s:设置堆栈指针,设置pc指针,初始化中断向量,配置系统时钟,对用c库函数_main最后去c语言世界里. 2 ...

随机推荐

  1. 中检测到有潜在危险的 Request.Form 值

    经常会出现从客户端(xxx)中检测到有潜在危险的 Request.Form 值. 这个问题我们只用在web.config中添加一句代码即可 <system.web> <pages v ...

  2. Django mysql-client

    sudo apt-get install libmysqlclient-dev 报错,mysqlclient 没有安装 :实际已经安装,这是因为mysql安装时没有安装好 https://www.cn ...

  3. oddo

    看了这张图,或许你对odoo有了一些兴趣. https://www.cnblogs.com/wterp/p/9093616.html 这次就是和大家一起交流开源ERP/CRM系统:odoo 对以下读者 ...

  4. go变量的定义并赋值

    变量在定义时没有明确的初始化时会赋值为_零值_. 零值是: 数值类型为 `0`, 布尔类型为 `false`, 字符串为 `""`(空字符串). package main impo ...

  5. BZOJ3879 SvT(后缀树+虚树)

    对反串建SAM得到后缀树,两后缀的lcp就是其在后缀树上lca的len值,于是每次询问对后缀树建出虚树并统计答案即可. #include<iostream> #include<cst ...

  6. python03-break、continue、for循环、数据bytes类型、字符串与字节的关系、变量指向与深浅拷贝、set集合、文件操作

    目录: 1.break.continue 2.for循环 3.数据bytes类型 4.字符串与字节的关系 5.变量指向与深浅拷贝 6.set集合 7.文件操作 一.break.continue bre ...

  7. 面试经典算法:马拉松算法,最长回文子串Golang实现

    求一个字符串中最长的回文子串. package main import "fmt" /* 马拉松算法,求最长回文子串,时间复杂度:线性 */ func main() { // 回文 ...

  8. Swiper 轮播插件 之 动态加载无法滑动

    1.原因:轮播图未完全动态加载完成,即初始化 2.方法一:ajax链式编程 $.ajax({ type: "get", url: serviceURL + "/listB ...

  9. 数据格式转换string.Format

    1.格式化货币(跟系统的环境有关,中文系统默认格式化人民币,英文系统格式化美元) string.Format("{0:C}",0.2) 结果为:¥0.20 (英文操作系统结果:$0 ...

  10. javadoc 自动生成java帮助文档

    用法: javadoc [options] [packagenames] [sourcefiles] 选项: -public 仅显示 public 类和成员 -protected 显示 protect ...