#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. 【c# 学习笔记】数值类型

    c# 中的数值类型分为:整型.浮点型.十进制.如下图. 1.整型数值的取值范围和内存大小 类型 说明 取值范围 byte 无符号的8位整数 0到255(即2的8次方-1) sbyte   有符号的8位 ...

  2. 2.app自动化测试--adb常用API

    adb常用API  Driver.current_activity 获取当前运行应用界面的启动名 Driver.current_package 获取当前运行应用的包名 Driver.contexts ...

  3. 【数据库开发】C++测试redis中的publish/subscribe

    运用 http://blog.csdn.net/xumaojun/article/details/51558237 中的redis_publisher.hredis_publisher.cpp red ...

  4. Word 双栏排版最后多一页空白页删不掉、左栏文字没写完就到右栏了

    1. 问题 问题:Word双栏排版,最后多一页空白页,删不掉.如图: 原因分析:删不掉是因为末尾文字处其实有个下一页分节符,只不过可能看不到. 如何清晰的看到? 视图 > 大纲,就可以看到了.如 ...

  5. Centos 修改IP地址、网关、DNS

    一.CentOS 修改IP地址   修改对应网卡的IP地址的配置文件 # vi /etc/sysconfig/network-scripts/ifcfg-eth0   电信 # vi /etc/sys ...

  6. Spring cloud的各类组件

    Spring cloud 的各类组件 1.注册中心 eureka 2.ribbon 3.feign 4.hystirx 断路器 5.高速缓存器 redis 6.断路器Dashboard监控仪表盘

  7. 【百度之星2019】Strassen

    [题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=6719 在本题中,我们只有两种方法计算两个的矩阵的乘积,第一种为定义法,需要次乘法和次加法.第二种为 ...

  8. 一个农民工自学java找到工作的励志故事

    <!-----------------------------------------------------------------------------摘自网络-------------- ...

  9. nacos搭建

    1.下载执行包 直接官网 https://nacos.io/zh-cn/docs/quick-start.html 2. 建表 3. 启动 http://10.0.0.113:8848/nacos/i ...

  10. MySQL 触发器的使用

    MySQL 基础篇 三范式 MySQL 军规 MySQL 配置 MySQL 用户管理和权限设置 MySQL 常用函数介绍 MySQL 字段类型介绍 MySQL 多列排序 MySQL 行转列 列转行 M ...