快速构建一个ui界面程序--pyqt入门

快速构建一个ui界面程序--pyqt入门

  • [0 背景](#0 背景)
  • [1 环境准备](#1 环境准备)
    • [1.1 安装python](#1.1 安装python)
    • [1.2 安装pyqt](#1.2 安装pyqt)
  • [2 UI设计](#2 UI设计)
    • [2.1 启动UI设计可视化工具](#2.1 启动UI设计可视化工具)
    • [2.2 生成*.ui文件](#2.2 生成*.ui文件)
    • [2.3 编译ui生成对应的py](#2.3 编译ui生成对应的py)
  • [3 使用UI](#3 使用UI)

0 背景

本文档用于记录开发者如何快速构建一个简单UI程序。开发者使用文档中提及的工具并用于商业活动时,请注意对应工具的使用协议。

本文介绍如何使用pyqt快速构建一个简单UI,此类需求常见于个人小型工具可视化,原型机demo开发的场景中。

选用pyqt进行UI构建的一个原因:

1 环境准备

1.1 安装python

这个不细讲,linux一般出厂自带python工具,其它系统参考python官网

1.2 安装pyqt

命令行环境下使用pip工具进行安装,如果无法下载,请搜索"python 安装 pyqt"。以下命令考虑国内开发者,使用了华为的pip源加速。

bash 复制代码
pip install PyQt5 -i https://mirrors.huaweicloud.com/repository/pypi/simple
pip install pyqt5-tools -i https://mirrors.huaweicloud.com/repository/pypi/simple

2 UI设计

2.1 启动UI设计可视化工具

安装pyqt时会对应按照Designer工具,用于做可视化的界面设计。可以在任务栏搜索到对应的工具。也可以在命令行窗口输入designer来启动这个工具。

2.2 生成*.ui文件

进入designer可视化设计界面之后,左上角"文件"->"新建"。

创建一个界面设计的窗体,这里我们直接默认MainWindow就好。


按上图的方式设计一个简易的UI。选中"文件"->"另存为",保存即生成对应的.ui文件了。我这里偷懒,就叫ui.ui了。空间还可以改对应的名字,这里也偷懒,就保留了默认名字。

2.3 编译ui生成对应的py

命令行中,使用pyuic工具编译ui文件,把ui.ui编译为python脚本。

bash 复制代码
pyuic5 -o ui.py ui.ui

查看一下生成的ui.py,关注到里头就一个类Ui_MainWindow。我们需要重点关注的就是类中setupUi接口。

python 复制代码
# auto generated ui.py
class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
    	# ...

稍微读一下setupUi,发现里面是在设置我们的MainWindow 名字大小等属性,并创建pushButtonlabel控件。猜测我们把一个显示在前端的MainWindow对象传给setupUi,它就会帮我们按ui.ui文件进行设置。自此,我们的前端ui设计工作就完成了,我们只需要在主函数搞一个前端MainWindows,传给setupUi即可。

3 使用UI

根据第2节对ui.py的猜测,构造一个使用该UI的范例main.py如下:

python 复制代码
# -- coding: utf-8 -- 

import sys
from PyQt5.QtWidgets import QApplication, QMainWindow, QVBoxLayout, QWidget, QLabel, QComboBox
# 从生成的代码ui.py中导入Ui_MainWindow类
from ui import Ui_MainWindow as Ui_MainWindow

# 创建一个MainWindow类,继承于QMainWindow
class MainWindow(QMainWindow):
    def __init__(self):
        super().__init__()
        # 持有一个ui格式
        self.ui = Ui_MainWindow()
        # 将自己传给ui,让它帮忙设计样式
        self.ui.setupUi(self)
        # 将ui中pushButton控件的clicked事件关联到处理函数on_click
        self.ui.pushButton.clicked.connect(self.on_click)

	# pushButton的回调函数,注意这个名字并非限定为on_click
    def on_click(self):
    	# 使用ui中的label显示"clicked"
        self.ui.label.setText("clicked!")


if __name__ == "__main__":
	# 启动一个前端窗口标准操作
    app = QApplication(sys.argv)
    window = MainWindow()
    window.show()
    sys.exit(app.exec_())

main.py中,把控件pushButtonclicked 事件(Qt里面有时候也叫信号)和回调函数on_click关联了起来。然后在on_click里面设置控件label进行输出。

对于pushButton控件和label控件有哪些信号,对应的回调函数入参是什么,还有哪些功能,本文不深入探究,有需要的开发者请参考Qt的文档进行查询。

命令行执行python main.py,效果如下:

点击按钮,结果如下。

可以看到点击按钮后,label的输出发生了变化。自此,我们完成了一个最简易的前端UI搭建。开发者后面根据具体情况随机应变即可。

相关推荐
计算机毕业编程指导师8 分钟前
大数据可视化毕设:Hadoop+Spark交通分析系统从零到上线 毕业设计 选题推荐 毕设选题 数据分析 机器学习 数据挖掘
大数据·hadoop·python·计算机·spark·毕业设计·城市交通
计算机毕业编程指导师16 分钟前
【计算机毕设选题】基于Spark的车辆排放分析:2026年热门大数据项目 毕业设计 选题推荐 毕设选题 数据分析 机器学习 数据挖掘
大数据·hadoop·python·计算机·spark·毕业设计·车辆排放
浔川python社21 分钟前
浔川社团关于产品数据情况的官方通告
python
生活很暖很治愈23 分钟前
GUI自动化测试[3]——控件&数鼠标操作
windows·python·功能测试·测试工具
老蒋每日coding34 分钟前
Python3基础练习题详解,从入门到熟练的 50 个实例(一)
开发语言·python
HAPPY酷40 分钟前
构建即自由:一份为创造者设计的 Windows C++ 自动化构建指南
开发语言·c++·ide·windows·python·策略模式·visual studio
瑶池酒剑仙42 分钟前
Libvio.link爬虫技术解析大纲
爬虫·python
喵手1 小时前
Python爬虫实战:构建 Steam 游戏数据库:requests+lxml 实战游戏列表采集与价格监控(附JSON导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集steam商店游戏列表数据·sqlite数据库存放采集数据·价格监控游戏推荐市场分析
老蒋每日coding1 小时前
LangGraph:从入门到Multi-Agent超级智能体系统进阶开发
开发语言·python
UI设计兰亭妙微1 小时前
UI 设计新范式:从国际案例看体验与商业的融合之道
人工智能·ui·b端设计