【pyqt】(八)ui文件使用

news/2025/1/13 7:57:12/

ui_0">ui文件使用

前面我们已经学过了简单的UI文件创建(利用Qt Designer)和基础控件的使用。现在我们学习如何把二者融合起来完成开发。UI文件以 XML 格式存储界面的布局和各种控件的属性,我们可以利用Qt Designer开发界面,然后利用代码来实现后端的逻辑编程。这样可以将界面设计部分与逻辑编程部分分离,使得代码结构更加清晰。

在代码中调用ui文件有两种方法,一是动态调用,二是将其转为py文件之后调用。

动态调用

动态调用ui文件主要使用QUiLoader类完成,其需要在QApplication之前先实例化

这里使用我们之前使用Designer做的登录框例子,

from PySide6.QtWidgets import QApplication,QWidget
from PySide6.QtUiTools import QUiLoaderuiLoader = QUiLoader()
class MyWindow(QWidget):def __init__(self):uiltin">super().__init__()self.ui = uiLoader.load("登录框.ui")  # 注意此处的路径,如果和当前python文件不在同一文件需要指定明确路径if __name__ == '__main__':app = QApplication()window = MyWindow()window.ui.show()app.exec()

转换py文件

在命令行中使用这个命令将ui文件转为py文件

pyside6-uic ./ui/登录框.ui > login.py

py文件中的内容如下所示,它不像我们搭建的框架,把内容都写在init方法中,而是使用一个setupUi方法

在这里插入图片描述

from PySide6.QtWidgets import QApplication,QWidget
from login import Ui_widget  # 导入生成的UI类class MyWindow(QWidget):def __init__(self):uiltin">super().__init__()self.ui = Ui_widget()  # 用一个属性来实例化self.ui.setupUi(self)  # 设置UIif __name__ == '__main__':app = QApplication()window = MyWindow()window.show()app.exec()

实战-登录框

我们之前已经利用Designer实现过登录框的ui文件,现在让我们将其导入之后实现一下其登录的逻辑(简单实现,不连接数据库)。此处无论是使用动态加载还是静态加载的方法都是一样的。

from PySide6.QtWidgets import QApplication,QWidget
from login import Ui_widgetclass MyWeidget(QWidget):def __init__(self):uiltin">super().__init__()self.ui = Ui_widget()self.ui.setupUi(self)# 这里的对象名要和Designer中的QObjectName对应self.ui.pushButton.clicked.connect(self.judgeUser)def judgeUser(self):account = self.ui.lineEdit.text()password = self.ui.lineEdit_2.text()if account=="123" and password=="123":print("登录成功")else:print("账号或密码错误")if __name__ == '__main__':app = QApplication()window = MyWeidget()window.show()app.exec()

在这里插入图片描述

实战-计算器

我们实现一个简单的计算器界面如下,这里面的很多按键使用布局将它们排列整齐,然后给所有的控件都起一个合适的名字(QObjectName),这样方便我们在使用代码实现逻辑。

在这里插入图片描述

from PySide6.QtWidgets import QApplication,QWidget
from PySide6.QtUiTools import QUiLoaderclass MyWindow(QWidget):def __init__(self):uiltin">super().__init__()self.ui = uiLoader.load(r"ui/计算器.ui")self.bind()self.result = ''def bind(self):self.ui.pushButton_0.clicked.connect(lambda:self.addNumber('0'))self.ui.pushButton_1.clicked.connect(lambda:self.addNumber('1'))self.ui.pushButton_2.clicked.connect(lambda:self.addNumber('2'))self.ui.pushButton_3.clicked.connect(lambda:self.addNumber('3'))self.ui.pushButton_4.clicked.connect(lambda:self.addNumber('4'))self.ui.pushButton_5.clicked.connect(lambda:self.addNumber('5'))self.ui.pushButton_6.clicked.connect(lambda:self.addNumber('6'))self.ui.pushButton_7.clicked.connect(lambda:self.addNumber('7'))self.ui.pushButton_8.clicked.connect(lambda:self.addNumber('8'))self.ui.pushButton_9.clicked.connect(lambda:self.addNumber('9'))self.ui.pushButton_dot.clicked.connect(lambda:self.addNumber('.'))self.ui.pushButton_add.clicked.connect(lambda:self.addNumber('+'))self.ui.pushButton_min.clicked.connect(lambda:self.addNumber('-'))self.ui.pushButton_mul.clicked.connect(lambda:self.addNumber('*'))self.ui.pushButton_div.clicked.connect(lambda :self.addNumber('/'))self.ui.pushButton_equal.clicked.connect(self.equal)self.ui.pushButton_clear.clicked.connect(self.clear)self.ui.pushButton_back.clicked.connect(self.back)def addNumber(self,num):self.ui.textEdit.clear()self.result+=numself.ui.textEdit.setText(self.result)def equal(self):self.numresult = uiltin">eval(self.result)self.ui.textEdit.setText(uiltin">str(self.numresult))def clear(self):self.result = ''self.ui.textEdit.clear()def back(self):self.ui.textEdit.clear()self.result = self.result[:-1]self.ui.textEdit.setText(self.result)if __name__ == '__main__':uiLoader = QUiLoader()app = QApplication()window = MyWindow()window.ui.show()app.exec()

http://www.ppmy.cn/news/1562755.html

相关文章

【Redis入门到精通六】在Spring Boot中集成Redis(含配置和操作演示)

目录 Spring Boot中集成Redis 1.项目创建和环境配置 2.基本操作演示 Spring Boot中集成Redis Spring社区也自定义了一套Redis的客户端,与jedis的操作方式有所差异,Spring中把每个类型的操作都单独封装了起来。下面就让我来带大家了解如何在Spring Bo…

JavaScript 学习总结

一、基础语法 1. 变量声明 var:ES5 中用于声明变量,有函数作用域和变量提升现象。变量提升意味着变量可以在声明之前使用,但其值为 undefined。 console.log(a); // 输出: undefined var a 10; let:ES6 引入,具有…

[Python学习日记-75] 计算机基础与网络

[Python学习日记-75] 计算机基础与网络 简介 计算机基础 什么是网络编程 计算机网络 简介 本篇主要介绍的计算机基础是浓缩的,这是因为我们主要学习的是 Python,而 Python 主要是为了开发应用程序的,并不会用它来开发操作系统和嵌入式程序…

网络安全设备bypass

一. 什么是bypass 网络安全设备一般都是应用在两个或更多的网络之间,比如内网和外网之间,网络安全设备内的应用程序会对通过他的网络封包来进行分析,以判断是否有威胁存在,处理完后再按照一定的路由规则将封包转发出去&#xff0c…

大模型LLM-Prompt-CRISPE

1 CRISPE "CRISPE"是一个用于构建有效提示词(Prompt)的框架,特别适用于需要AI扮演特定角色或在特定背景下完成任务的场景。以下是"CRISPE"框架的组成部分: Capacity and Role(能力和角色&#xf…

UML系列之Rational Rose笔记四:时序图(顺序图_序列图)

时序图有很多画法,这基本上能算rose里面要求最乱的一种图了;有些人的需求是BCE模式,这是正常规范点的,有些人就不需要,有些需要用数据库交互,有些不需要;没有一个较为统一的需求;在此…

安卓硬件加速hwui

安卓硬件加速 本文基于安卓11。 从 Android 3.0 (API 级别 11) 开始,Android 2D 渲染管道支持硬件加速,这意味着在 View 的画布上执行的所有绘图操作都使用 GPU。由于启用硬件加速所需的资源增加,你的应用程序将消耗更多内存。 软件绘制&am…

PHP Filesystem

《PHP Filesystem》是一组允许您访问和操作文件系统的函数,是PHP核心的一部分。您无需安装即可使用这些函数。Filesystem函数的行为受到php.ini中设置的影响,包括选项如allowurlfopen、useragent、defaultsockettimeout等。这些函数在Unix和Windows平台上…