python 실시 간 모니터링 cpu 도구
완벽 하 게 쓰 지 는 않 았 지만 연습 을 해 보 세 요.cpu 를 실시 간 으로 감시 하 는 데 도움 이 됩 니 다.안 드 로 이 드 스튜디오 는 같은 기능 을 제 공 했 지만 로 컬 csv 파일 로 기록 하고 생 성 할 수 있 는 것 은 as 보다 한 가지 기능 이 더 많 습 니 다.
결과 그림:
직접 소스 코드 넣 기:
# !_*_coding:utf-8_*_
import re
import os
import wx
import thread
import pychartdir
import csv
class GetCpuStats():
def __init__(self, name):
self.pro_name = name
def startWatch(self):
_shell = 'adb shell top -s cpu -n 1| findstr %s' % self.pro_name
result = os.popen(_shell).read()
return self.getInfo(result)
def getInfo(self, _result):
return [re.findall('(\d+)%', _result), re.findall('K\s(\d+)K', _result)]
class MyFrame(wx.Frame):
flag = False
_label = []
_data = []
_label02 = []
_data02 = []
num = 0
num02 = 0
def __init__(self):
wx.Frame.__init__(self, parent=None, title=u'cpu ', pos=(700, 100), size=(500, 500))
mPanel = wx.Panel(parent=self)
mSizer = wx.BoxSizer(orient=wx.VERTICAL)
btn_start = wx.Button(parent=mPanel, label=u' ', style=wx.EXPAND)
mSizer.Add(btn_start)
btn_stop = wx.Button(parent=mPanel, label=u' ', style=wx.EXPAND)
mSizer.Add(btn_stop)
self.edit = wx.TextCtrl(parent=mPanel,style=wx.EXPAND,value=u' ')
mSizer.Add(self.edit,flag=wx.EXPAND)
self.edit.Bind(event=wx.EVT_CHOICE, handler=self.requestFocus)
self.bitmap_cpu = wx.StaticBitmap(parent=mPanel)
mSizer.Add(self.bitmap_cpu, flag=wx.EXPAND)
#self.bitmap_mem = wx.StaticBitmap(parent=mPanel)
#mSizer.Add(self.bitmap_mem, flag=wx.EXPAND)
mPanel.SetSizer(mSizer)
mPanel.Fit()
btn_start.Bind(event=wx.EVT_BUTTON, handler=self.startWatch)
btn_stop.Bind(event=wx.EVT_BUTTON, handler=self.stopWatch)
def requestFocus(self,event):
self.edit.SetValue("")
def startWatch(self, event):
self.flag = True
thread.start_new_thread(self.getInfo, ())
def stopWatch(self, event):
self.flag = False
def getInfo(self):
while(self.flag):
_result = GetCpuStats(self.edit.GetValue()).startWatch()
self.drawPic(_result)
#self.drawPic_mem(_result)
def writeCsv(self, _list):
writer = csv.writer(file('tmp.csv', 'a+'))
writer.writerow([_list])
def drawPic(self,_list):
self.num+=1
self._label.append(str(self.num))
self._data.append(_list[0][0])
self.writeCsv(_list[0][0])
c = pychartdir.XYChart(500, 400)
c.setPlotArea(30, 20, 400, 300)
c.addLineLayer(self._data)
c.xAxis().setLabels(self._label)
c.makeChart("tmp.png")
mImage = wx.Image("tmp.png")
mImage = mImage.Scale(500,300)
self.bitmap_cpu.SetBitmap(wx.BitmapFromImage(mImage))
def drawPic_mem(self,_list):
self.num02+=1
self._label02.append(str(self.num02))
self._data02.append(_list[1][0])
c = pychartdir.XYChart(500, 400)
c.setPlotArea(60, 40, 400, 300)
c.addLineLayer(self._data02)
c.xAxis().setLabels(self._label02)
c.makeChart("tmp02.png")
mImage = wx.Image("tmp02.png")
mImage = mImage.Scale(500,300)
self.bitmap_mem.SetBitmap(wx.BitmapFromImage(mImage))
if __name__ == '__main__':
app = wx.App()
MyFrame().Show()
app.MainLoop()
원리:인 터 페 이 스 는 wx 로 만 들 었 습 니 다.도형 은 pychartdir 로 만 들 었 습 니 다.명령 은 top 명령 을 사 용 했 습 니 다.캡 처 한 데 이 터 는 매번 임시 그림 을 만 들 고 화면 에 새로 고침 되 었 습 니 다.실시 간 데이터 모니터링 효과 인 것 같 습 니 다.기본적으로 BUG 가 많 고 고치 기 귀 찮 습 니 다.
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
로마 숫자를 정수로 또는 그 반대로 변환그 중 하나는 로마 숫자를 정수로 변환하는 함수를 만드는 것이었고 두 번째는 그 반대를 수행하는 함수를 만드는 것이었습니다. 문자만 포함합니다'I', 'V', 'X', 'L', 'C', 'D', 'M' ; 문자열이 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.