当前位置: 首页 > news >正文

基于PyQt5的图形化界面开发——Windows内存资源监视助手[附带编译exe教程]

基于PyQt5的图形化界面开发——Windows内存资源监视助手[附带编译exe教程]

  • 0. 前言
  • 1. 资源信息获取函数——monitor.py
  • 2. UI界面——listen.py
  • 3. main.py
  • 4. 运行效果
  • 5. 编译 exe 程序
  • 6. 其他PyQt文章

0. 前言

利用 PyQt5 开发一个 windows 的资源监视助手,在使用虚拟机的时候有大用,因为某些缘故我需要同时开启多个虚拟机,开多了往往会卡,所以需要进行简单拿到监视内存看看是否内存够用。

操作系统:Windows10 专业版

开发环境:Pycahrm Comunity 2022.3

Python解释器版本:Python3.8

第三方库:PyQt5、psutil

显示器分辨率:1920 x 1080

1. 资源信息获取函数——monitor.py

使用下面这个函数来获取内存、CPU等资源信息

# code:utf-8
# Create by Maxtang
# 2023/5/3
import psutildef monitor():mem = psutil.virtual_memory()# 系统总计内存cpu = psutil.cpu_percent(interval=0.2)percent = mem.used / mem.total# 内存总量total = float(mem.total) / 1024 / 1024 / 1024# 已经使用used = float(mem.used) / 1024 / 1024 / 1024# 剩余量free = float(mem.free) / 1024 / 1024 / 1024# cpu占用cpu = str(cpu)[:4]# 内存占用百分比percent = str(percent)[:6]used = str(used)[:4]free = str(free)[:4]total = str(total)[:4]# li = [cpu, total,used,free,percent]# print(li)data = {"cpu":cpu,"total":total,"used":used,"free":free,"percent":percent}return dataif __name__ == '__main__':print(monitor())

效果如下:
在这里插入图片描述

2. UI界面——listen.py

这个就没什么好说的,创建一个Python文件命名为 listen.py 就好了

# -*- coding: utf-8 -*-# Form implementation generated from reading ui file '.\listen.ui'
#
# Created by: PyQt5 UI code generator 5.15.4
#
# WARNING: Any manual changes made to this file will be lost when pyuic5 is
# run again.  Do not edit this file unless you know what you are doing.from PyQt5 import QtCore, QtGui, QtWidgetsclass Ui_MainWindow(object):def setupUi(self, MainWindow):MainWindow.setObjectName("MainWindow")MainWindow.resize(355, 135)self.centralwidget = QtWidgets.QWidget(MainWindow)self.centralwidget.setObjectName("centralwidget")self.widget = QtWidgets.QWidget(self.centralwidget)self.widget.setGeometry(QtCore.QRect(0, 0, 352, 39))self.widget.setObjectName("widget")self.gridLayout = QtWidgets.QGridLayout(self.widget)self.gridLayout.setContentsMargins(0, 0, 0, 0)self.gridLayout.setObjectName("gridLayout")self.label_6 = QtWidgets.QLabel(self.widget)self.label_6.setAlignment(QtCore.Qt.AlignCenter)self.label_6.setObjectName("label_6")self.gridLayout.addWidget(self.label_6, 1, 1, 1, 1)self.label_4 = QtWidgets.QLabel(self.widget)self.label_4.setAlignment(QtCore.Qt.AlignCenter)self.label_4.setObjectName("label_4")self.gridLayout.addWidget(self.label_4, 0, 3, 1, 1)self.label_3 = QtWidgets.QLabel(self.widget)self.label_3.setAlignment(QtCore.Qt.AlignCenter)self.label_3.setObjectName("label_3")self.gridLayout.addWidget(self.label_3, 0, 2, 1, 1)self.label = QtWidgets.QLabel(self.widget)self.label.setAlignment(QtCore.Qt.AlignCenter)self.label.setObjectName("label")self.gridLayout.addWidget(self.label, 0, 0, 1, 1)self.label_8 = QtWidgets.QLabel(self.widget)self.label_8.setAlignment(QtCore.Qt.AlignCenter)self.label_8.setObjectName("label_8")self.gridLayout.addWidget(self.label_8, 1, 2, 1, 1)self.label_5 = QtWidgets.QLabel(self.widget)self.label_5.setAlignment(QtCore.Qt.AlignCenter)self.label_5.setObjectName("label_5")self.gridLayout.addWidget(self.label_5, 1, 0, 1, 1)self.label_7 = QtWidgets.QLabel(self.widget)self.label_7.setAlignment(QtCore.Qt.AlignCenter)self.label_7.setObjectName("label_7")self.gridLayout.addWidget(self.label_7, 1, 3, 1, 1)self.label_2 = QtWidgets.QLabel(self.widget)self.label_2.setObjectName("label_2")self.gridLayout.addWidget(self.label_2, 0, 1, 1, 1)self.widget1 = QtWidgets.QWidget(self.centralwidget)self.widget1.setGeometry(QtCore.QRect(30, 40, 295, 30))self.widget1.setObjectName("widget1")self.horizontalLayout = QtWidgets.QHBoxLayout(self.widget1)self.horizontalLayout.setContentsMargins(0, 0, 0, 0)self.horizontalLayout.setObjectName("horizontalLayout")self.pushButton = QtWidgets.QPushButton(self.widget1)self.pushButton.setObjectName("pushButton")self.horizontalLayout.addWidget(self.pushButton)self.pushButton_2 = QtWidgets.QPushButton(self.widget1)self.pushButton_2.setObjectName("pushButton_2")self.horizontalLayout.addWidget(self.pushButton_2)self.pushButton_3 = QtWidgets.QPushButton(self.widget1)self.pushButton_3.setObjectName("pushButton_3")self.horizontalLayout.addWidget(self.pushButton_3)MainWindow.setCentralWidget(self.centralwidget)self.menubar = QtWidgets.QMenuBar(MainWindow)self.menubar.setGeometry(QtCore.QRect(0, 0, 355, 26))self.menubar.setDefaultUp(False)self.menubar.setNativeMenuBar(False)self.menubar.setObjectName("menubar")MainWindow.setMenuBar(self.menubar)self.statusbar = QtWidgets.QStatusBar(MainWindow)self.statusbar.setObjectName("statusbar")MainWindow.setStatusBar(self.statusbar)self.retranslateUi(MainWindow)QtCore.QMetaObject.connectSlotsByName(MainWindow)def retranslateUi(self, MainWindow):_translate = QtCore.QCoreApplication.translateMainWindow.setWindowTitle(_translate("MainWindow", "Windows资源监视器"))self.label_6.setText(_translate("MainWindow", "TextLabel"))self.label_4.setText(_translate("MainWindow", "内存占用百分比"))self.label_3.setText(_translate("MainWindow", "剩余内存/G"))self.label.setText(_translate("MainWindow", "CPU"))self.label_8.setText(_translate("MainWindow", "TextLabel"))self.label_5.setText(_translate("MainWindow", "TextLabel"))self.label_7.setText(_translate("MainWindow", "TextLabel"))self.label_2.setText(_translate("MainWindow", "内存占用/G"))self.pushButton.setText(_translate("MainWindow", "启动"))self.pushButton_2.setText(_translate("MainWindow", "终止"))self.pushButton_3.setText(_translate("MainWindow", "退出"))

3. main.py

下面这个就是main函数,你需要先创建以上文件 [monitor.py、listen.py] ,否则将会报错无法运行

import sys
from PyQt5 import  QtWidgets
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *
from PyQt5.QtCore import *import listen
from monitor import monitor
import timeclass UI(QMainWindow, listen.Ui_MainWindow):def __init__(self):super(UI, self).__init__()self.setupUi(self)self.pushButton.clicked.connect(lambda:{self.start(),self.fun()})self.pushButton_2.clicked.connect(lambda:{self.join(),self.fun()})self.pushButton_3.clicked.connect(lambda:{exit(0)})self.move((1920-355)//2,1080-120)# 隐藏任务栏图标self.setWindowFlags(Qt.WindowStaysOnTopHint | Qt.SplashScreen | Qt.FramelessWindowHint | Qt.FramelessWindowHint)# 设置窗口背景透明self.setWindowOpacity(0.85)  # 设置窗口透明度self.setAttribute(Qt.WA_TranslucentBackground)  # 设置窗口背景透明# # 设置按钮透明# op = QtWidgets.QGraphicsOpacityEffect()# op.setOpacity(0.35) # 设置透明度的值,0.0到1.0,最小值0是透明,1是不透明# self.pushButton.setGraphicsEffect(op)global flagflag = 0def start(self):global flagflag = 1# print("start")def join(self):global flagflag = 0# print("join")def fun(self):# print("ok")while flag == 1:data = monitor()self.label_5.setText("{}%".format(data["cpu"]))self.label_6.setText("{}/{}G".format(data["used"],data["total"]))self.label_8.setText("{}/{}G".format(data["free"],data["total"]))self.label_7.setText("{:.2f}%".format(float(data["percent"])*100))QtWidgets.QApplication.processEvents()time.sleep(0.2)app = QtWidgets.QApplication(sys.argv)
main = UI()
main.show()
sys.exit(app.exec_())

4. 运行效果

按下启动按键之后,就会开始监视计算机的CPU资源,它是刚好浮于状态栏上方的,这个位置被我调整过。而且由于下面的代码,导致它不显示选项卡和任务栏图标:

self.setWindowFlags(Qt.WindowStaysOnTopHint | Qt.SplashScreen | Qt.FramelessWindowHint | Qt.FramelessWindowHint)

在这里插入图片描述

5. 编译 exe 程序

为了避免每次都需要打开Pycharm项目,我决定将它编译为 exe 程序,这样一来我只需要双机程序就能运行了

Python不像C语言,需要我们安装第三方库来进行编译。

第三方库:Pyinstaller,首先你需要安装 Pyinstaller 库,如果你还不会安装库,你可以参考我的这个文章来学习:

Python第三方库安装——使用vscode、pycharm安装Python第三方库

在我们的项目所在目录打开 PowerShell
在这里插入图片描述
然后输入以下命令:

Pyinstaller -F main.py

在这里插入图片描述

历时30多秒后控制台提示我们编译成功:
在这里插入图片描述
这时候回到你的项目目录下,在这个里面,你能找到你编译好的程序:
在这里插入图片描述
双击它就可以运行啦!
在这里插入图片描述

我给它增加了一点其他功能,让它不只是资源监视那么简单,我增加了一个爬虫来爬取我csdn的状态信息,为了不被系统检测到爬虫攻击,我选择的是使用手动更新按钮:
在这里插入图片描述

在这里插入图片描述

6. 其他PyQt文章

如果你对 PyQt 学习有点兴趣,你可以看看我的其他PyQt文章:

基于PyQt5的图形化界面开发——自制MQTT客户端软件
基于PyQt5的图形化界面开发——自制Redis图形化客户端
基于PyQt5的图形化界面开发——模拟医院管理系统
基于PyQt5的图形化界面开发——PyQt示例_计算器
基于PyQt5的图形化界面开发——PyQt示例_扫雷

http://www.lryc.cn/news/70408.html

相关文章:

  • Linus Torvalds发布了第一个Linux内核6.4候选版本
  • 由浅入深Dubbo核心源码剖析环境介绍
  • Java 远程连接 SQLite 数据库
  • 网安面试题大全(附答案)
  • windows 系统扩容C盘注意事项
  • 接入支付宝沙箱环境
  • 用原生JS实现虚拟列表(IT枫斗者)
  • FAT NTFS Ext3文件系统有什么区别
  • 信息收集思路
  • Tauri应用开发(二):创建第一个Tauri应用
  • 自信裸辞:一晃 ,失业都3个月了.....
  • Python3 输入和输出
  • Mybatis Plus 使用@TableLogic实现逻辑删除
  • 2023/5/23总结
  • Squid代理服务器应用
  • 网络编程中的sockfd是什么?
  • 如何利用Citespace和vosviewer既快又好地写出高质量的论文及快速锁定热点和重点文献进行可视化分析?
  • (学习日记)AD学习 #1
  • 缓存存在的问题
  • ChatGPT 的 AskYourPDF 插件所需链接如何获取?
  • 基于自营配送模式的车辆路径规划设计与实现_kaic
  • 动态规划-树形DP
  • 多线程基础(二)CAS无锁优化/自旋锁/乐观锁、ABA问题
  • 记ABAC的落地实践
  • 【C++】C++11线程库 和 C++IO流
  • cpp11实现线程池(六)——线程池任务返回值类型Result实现
  • 道岔外锁闭装置介绍
  • idea把项目上传到码云
  • 设计模式之责任链模式
  • Python--我一般都用这个模块压缩文件