【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_()

结果:

相关推荐
Morpheon11 小时前
Intro to R Programming - Lesson 4 (Graphs)
开发语言·r语言
代码AI弗森11 小时前
使用 JavaScript 构建 RAG(检索增强生成)库:原理与实现
开发语言·javascript·ecmascript
Tipriest_12 小时前
C++ 中 ::(作用域解析运算符)的用途
开发语言·c++·作用域解析
Swift社区12 小时前
Java 常见异常系列:ClassNotFoundException 类找不到
java·开发语言
MThinker12 小时前
k230 按键拍照后,将摄像头拍照的1920*1080分辨率的图片以jpg文件格式,保存到板载TF存储卡的指定文件夹目录中
python·嵌入式硬件·智能硬件·micropython·canmv·k230
Tipriest_13 小时前
求一个整数x的平方根到指定精度[C++][Python]
开发语言·c++·python
蓝倾97614 小时前
淘宝/天猫店铺商品搜索API(taobao.item_search_shop)返回值详解
android·大数据·开发语言·python·开放api接口·淘宝开放平台
ChuHsiang14 小时前
【Qt界面优化】QSS样式--伪类选择器
qt
John_ToDebug14 小时前
从源码看浏览器弹窗消息机制:SetDefaultView 的创建、消息转发与本地/在线页通用实践
开发语言·c++·chrome
跟橙姐学代码14 小时前
配置文件这么多格式,Python到底该怎么选?一文带你梳理七种常见用法
前端·python·ipython