【Python】QT(PySide2、PyQt5):Qt Designer,VS Code使用designer,可能的报错

Qt designer:

可直接在designer界面,使用拖拽的方式设计需要的界面,可设定部分属性。

安装Pyside2后,designer默认在python安装目录的Lib/sit_packages/PySide2文件夹中。

designer使用:

① 双击打开designer.exe,创建窗体,若包含菜单栏、工具栏、状态栏则使用Main Window,没有则可使用Widget。

② 将需要的控件拖拽到窗体中,自行调整位置和大小,并修改对应的属性。特别注意属性ObjectName,调用控件或设置控件属性时就是使用ObjectName对应的值。其他属性例如字体font、文本内容text等。

③ 设计完成,点击保存,则生成 ui文件(默认与designer.exe在同一文件夹下)。

④ 使用ui文件:1、项目中导入ui文件。2、ui文件生成py文件,并调用py文件。

注:VS Code中可使用扩展启用designer,创建ui文件和自动生成对应的py文件,只需调用该文件即可。

ui文件的使用:

例如:ui文件(myui.ui)的效果图为:

方法1、ui文件导入到py文件中:
python 复制代码
from PySide2.QtUiTools import QUiLoader

window = QUiLoader().load(ui文件名)
window.show()

举例:

python 复制代码
from PySide2.QtWidgets import QApplication
from PySide2.QtUiTools import QUiLoader

class mywindow:
    def __init__(self):
        super().__init__()
        self.ui = QUiLoader().load('myui.ui')
        
if __name__ == '__main__':
    app = QApplication()
    window = mywindow()
    window.ui.show()
    app.exec_()

完整导入ui的代码:

python 复制代码
from PySide2.QtWidgets import QApplication, QMainWindow
from PySide2.QtUiTools import QUiLoader
from PySide2.QtCore import QFile, QIODevice
import sys

class mywindow:
    def __init__(self):
        super().__init__()
        # self.ui = QUiLoader().load('myui.ui')
        ui_filename = f"myui.ui"
        ui_file = QFile(ui_filename)
        if not ui_file.open(QIODevice.ReadOnly): 
            print(f"Can't open '{ui_filename}'. [{ui_file.errorString()}]")
            sys.exit(-1)

        loader = QUiLoader()
        self.ui = loader.load(ui_file)
        ui_file.close()
        if not self.ui: 
            print(f"'{ui_filename}' load failed. [{loader.errorString()}]")
            sys.exit(-1)
        
if __name__ == '__main__':
    app = QApplication()
    window = mywindow()
    window.ui.show()
    app.exec_()
方法2、使用命令行生成py文件,并调用:

命令行输入:pyside2-uic ui文件名 > py文件名

举例:

bash 复制代码
pyside2-uic myui.ui > amyui_ui.py

结果:(生成py文件,文件中类为Ui_MainWindow,类中主要方法为setupUi)

注意:ui文件生成的py文件中为对应的类和方法,需导入该文件并调用类和方法才算使用。

python 复制代码
from PySide2.QtWidgets import QMainWindow
from ui生成的py文件(不含.py) import py文件中的类

window = QMainWindow()
ui = py文件中的类()
ui.py文件中的方法(window)

举例:

python 复制代码
from PySide2.QtWidgets import QApplication, QMainWindow
# from PySide2.QtUiTools import QUiLoader
from amyui_ui import Ui_MainWindow

# class mywindow:
#     def __init__(self):
#         super().__init__()
#         self.ui = QUiLoader().load('myui.ui')

class mywindow(QMainWindow):
    def __init__(self):
        super().__init__()
        self.ui = Ui_MainWindow()
        self.ui.setupUi(self)
        
if __name__ == '__main__':
    app = QApplication()
    window = mywindow()
    window.show()
    app.exec_()
可能的报错:

报错信息:ValueError: source code string cannot contain null bytes。

原因:导入的文件字符编码不是UTF-8。(VS Code最下面状态栏可查看)

解决:将导入的文件字符编码改为UTF-8。

点击UTF-16LE -> 选择:Save with encoding -> 选择:UTF-8。

在VS Code中使用designer:

① 扩展(Extensios)--> 找到Qt for Python或者PySide --> 安装(Install)。

② 设置(Settings)--> 找到Qt for Python --> 在Designer:Path,Rcc:Path,Uic:Path分别输入对应designer.exe,rcc.exe,uic.exe的地址(均在python安装目录下Lib/sit_packages/PySide2文件夹中)。

③ 设置(Settings)--> 找到Qt for Python --> 在Uic:Option添加项(Add Item):-g python。若此步不操作,则自动生成的py文件中不是python语言。

④ 使用:项目文件夹下,右键点击"Create Qt UI File(designer)",在designer界面设计,保存后自动生成ui文件和py文件。自动生成的py文件只是创建了对应的类和方法,需在项目中调用该文件才算使用(使用参考上面命令行生成的py文件)。

designer设计后,额外设定属性:

此处关键是designer设计时各控件的属性ObjectName。

例如:日期选择器设定日历以及当前日期。此处日期选择器的ObjectName为dateEdit。

日期选择器(ObjectName为dateEdit)设定日历和当前日期:

ui.dateEdit.setCalendarPopup(True)

ui.dateEdit.setDate(QDate.currentDate())

此处,变量名ui为通过designer设计的界面窗口(可直接导入ui文件,也可ui文件转为py文件并调用)。

python 复制代码
from PySide2.QtWidgets import QApplication, QMainWindow
from amyui_ui import Ui_MainWindow
from PySide2.QtCore import QDate

class mywindow(QMainWindow):
    def __init__(self):
        super().__init__()
        self.ui = Ui_MainWindow()
        self.ui.setupUi(self)
        # 日期选择器(ObjectName为dateEdit)设定日历和当前日期
        self.ui.dateEdit.setCalendarPopup(True)
        self.ui.dateEdit.setDate(QDate.currentDate())
       
if __name__ == '__main__':
    app = QApplication()
    window = mywindow()
    window.show()
    app.exec_()

结果:

相关推荐
自由会客室18 小时前
在 Ubuntu24.04 上安装 JDK 21(Java 21)
java·开发语言
喜欢读源码的小白18 小时前
SpringBoot的启动流程原理——小白的魔法引擎探秘
java·开发语言·spring boot·springboot启动原理
夜幽青玄18 小时前
mybatis-plus调用报 org.springframework.dao.DataIntegrityViolationException 错误处理
开发语言·python·mybatis
洲覆18 小时前
Redis 内存淘汰策略
开发语言·数据库·redis·缓存
偶尔贪玩的骑士19 小时前
Kioptrix Level 1渗透测试
linux·开发语言·网络安全·php
それども19 小时前
忽略Lombok构建警告
java·开发语言·jvm
qiuiuiu41319 小时前
正点原子RK3568学习日志12-注册字符设备
linux·开发语言·单片机·学习·ubuntu
liu****19 小时前
20.哈希
开发语言·数据结构·c++·算法·哈希算法
MetaverseMan19 小时前
Java Spring 框架的`@Autowired` 注解 以及依赖注入分析
java·开发语言·spring
迎風吹頭髮19 小时前
Linux服务器编程实践58-getnameinfo函数:通过socket地址获取主机名与服务名
开发语言·数据库·php