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

结果:

相关推荐
keep_di16 分钟前
06-django中配置接口文档coreapi
后端·python·django
野木香17 分钟前
tdengine笔记
开发语言·前端·javascript
NanXi_XZ37 分钟前
kubernetes事件监控工具--Kube-Event
python·kubernetes
雪域迷影1 小时前
使用C++编写的一款射击五彩敌人的游戏
开发语言·c++·游戏
郝学胜-神的一滴1 小时前
享元模式(Flyweight Pattern)
开发语言·前端·c++·设计模式·软件工程·享元模式
Larry_Yanan1 小时前
QML学习笔记(四)QML新手入门其二:通过MouseArea让Rectangle实现鼠标三态
笔记·qt·ui
java1234_小锋2 小时前
Scikit-learn Python机器学习 - 回归分析算法 - Lasso 回归 (Lasso Regression)
python·算法·机器学习
小莞尔2 小时前
【51单片机】【protues仿真】基于51单片机恒温箱系统
c语言·开发语言·单片机·嵌入式硬件·51单片机
天天进步20152 小时前
React Server Components详解:服务端渲染的新纪元
开发语言·前端·javascript