vscode 配置使用pyqt5的详细步骤

 更新时间:2025年10月08日 10:14:27   作者:wzg2016  
本文给大家介绍vscode 配置使用pyqt5的详细步骤,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧

1. vscode 配置 pyqt_designer

给 vscode 安装插件 “PYQT Integration”,点击 “PYQT Integration” 插件界面的齿轮,选择“Settings”,进入该插件的设置页面:

进入以下界面:

配置1:设置 Pyuic 的路径

Pyuic用于将GUI界面的 .ui 文件转换为 .py 文件。

找到 “Pyqt-integration > Pyuic: Cmd”,填入安装PyQt5的虚拟环境中Pyuic的绝对路径,如下:

D:\data\...\venv_QT\Scripts\pyuic5

配置2:设置 QT designer 的路径

QT designer 是 QT 用来设计 GUI 的软件,通过拖拽组件可以快速构建GUI。

找到 " Pyqt-integration > Qtdesigner: Path ",输入虚拟环境中QT designer的绝对路径,如下:

D:\data\...\venv_QT\Lib\site-packages\qt5_applications\Qt\bin\designer

配置结果如下图所示:

## 2. 创建 .ui 文件

在 vscode 的文件目录下,点击鼠标右键,选择“PYQT:New Form”, 创建 qt 的 ui 界面,自动调用qt-designer打开

vscode自动调用qt-designer打开,创建并打开一个.ui文件,这里以创建 “Main Window”为例,介绍后续使用方法。

创建一个 “Main Window”,从左侧拖进来一个 button之后,“ctrl+s"保存,弹出如下对话框,保存为 .ui 文件

关闭qt-designer.

回到 vscode, 在刚刚保存的 .ui 文件上,鼠标右键,

  • PYQT:New Form : 用于创建一个新的.ui文件/界面
  • PYQT:Preview: 会显示 .ui 界面的效果
  • PYQT:Edit in Designer: 用 qt-designer 重新打开 .ui 文件进行编辑
  • PYQT: Compile Form 将 .ui 文件编译为 .py 文件,创建了一个python类,供后续界面功能的开发使用。

2. 编译 .ui 文件 得到 .py 文件

在vscode中,在上一步创建的 .ui 文件上,点击鼠标右键,选择 ”PYQT: Compile Form“ 选项,得到.py 文件,如下:

# -*- coding: utf-8 -*-
# Form implementation generated from reading ui file 'f:\_文件_\pyqt_tests\pyqt_designer_test_1\test_1.ui'
#
# Created by: PyQt5 UI code generator 5.15.9
#
# WARNING: Any manual changes made to this file will be lost when pyuic5 is
# run again.  Do not edit this file unless you know what you are doing.
from PyQt5 import QtCore, QtGui, QtWidgets
class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(640, 480)
        self.centralwidget = QtWidgets.QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")
        # 这里是对应组件的设置
        self.pushButton = QtWidgets.QPushButton(self.centralwidget)
        self.pushButton.setGeometry(QtCore.QRect(430, 360, 93, 28))
        self.pushButton.setObjectName("pushButton")
        MainWindow.setCentralWidget(self.centralwidget)
        self.menubar = QtWidgets.QMenuBar(MainWindow)
        self.menubar.setGeometry(QtCore.QRect(0, 0, 640, 26))
        self.menubar.setObjectName("menubar")
        MainWindow.setMenuBar(self.menubar)
        self.statusbar = QtWidgets.QStatusBar(MainWindow)
        self.statusbar.setObjectName("statusbar")
        MainWindow.setStatusBar(self.statusbar)
        self.retranslateUi(MainWindow)
        QtCore.QMetaObject.connectSlotsByName(MainWindow)
    def retranslateUi(self, MainWindow):
        _translate = QtCore.QCoreApplication.translate
        MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
        self.pushButton.setText(_translate("MainWindow", "PushButton"))

3. 简单使用 .ui 定义的界面,添加槽函数

from PyQt5.QtWidgets import QApplication, QMainWindow
import sys 
from Ui_test_1 import Ui_MainWindow
# 定义一个槽函数
def on_btn_ok():
    print("hello world")
# 创建一个空界面
app = QApplication(sys.argv) 
main_window = QMainWindow()  # 创建以恶搞窗口
# 调用ui文件编译得到的头文件,配置main_window
ui = Ui_MainWindow()        # 常见一个窗口配置类的类对象
ui.setupUi(main_window)     # 用 ui 类装饰 创建的 main_window
# 给 ui 界面中的pushButton组件添加槽函数
ui.pushButton.clicked.connect(on_btn_ok)
# 显示窗口
main_window.show()
sys.exit(app.exec_())

4. 高级使用 .ui 定义的界面

继承 QMainWindow, 与 第三步生成的 Ui_MainWindow 类,创建一个新的类,管理ui界面中的所有组件,以及添加槽函数。

from PyQt5.QtWidgets import QApplication, QMainWindow
import sys 
from Ui_test_1 import Ui_MainWindow
# 继承 Ui_MainWindow 与 QMainWindow 创建新类
class MyMainWindow(QMainWindow,Ui_MainWindow): #这里也要记得改
    def __init__(self,parent =None):
        super(MyMainWindow,self).__init__(parent) # QMainWindow 初始化
        self.setupUi(self)  # 用 Ui_MainWindow 的 setupui 函数给 QMainWindow 添加组件
        # 给QMainWindow 的组件添加槽函数
        self.pushButton.clicked.connect(self.slot_on_btn_clicked)
    # 定义槽函数
    def slot_on_btn_clicked(self):
        print("hello world!")
if __name__ == "__main__":
    app = QApplication(sys.argv)
    w = MyMainWindow()
    w.show()
    sys.exit(app.exec_())

到此这篇关于vscode 配置使用pyqt5的详细步骤的文章就介绍到这了,更多相关vscode 使用pyqt5内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python人工智能实战之以图搜图的实现

    Python人工智能实战之以图搜图的实现

    这篇文章主要为大家详细介绍了如何基于vgg网络和Keras深度学习框架实现以图搜图功能。文中的示例代码讲解详细,感兴趣的小伙伴可以学习一下
    2022-05-05
  • python批量图片处理简单示例

    python批量图片处理简单示例

    这篇文章主要介绍了python批量图片处理,涉及Python针对图片文件的遍历、判断、缩放等相关操作技巧,需要的朋友可以参考下
    2019-08-08
  • TensorFlow中tf.batch_matmul()的用法

    TensorFlow中tf.batch_matmul()的用法

    这篇文章主要介绍了TensorFlow中tf.batch_matmul()的用法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • django authentication 登录注册的实现示例

    django authentication 登录注册的实现示例

    本文主要介绍了使用Django内置的authentication功能实现用户注册和登录功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-11-11
  • 为什么入门大数据选择Python而不是Java?

    为什么入门大数据选择Python而不是Java?

    为什么入门大数据选择Python而不是Java?这篇文章就来谈谈学习大数据入门语言的选择,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-03-03
  • python中如何使用朴素贝叶斯算法

    python中如何使用朴素贝叶斯算法

    本文主要介绍了python中如何使用朴素贝叶斯算法的相关知识。具有很好的参考价值。下面跟着小编一起来看下吧
    2017-04-04
  • 使用python代码进行身份证号校验的实现示例

    使用python代码进行身份证号校验的实现示例

    这篇文章主要介绍了使用python代码进行身份证号校验的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11
  • Python 整行读取文本方法并去掉readlines换行\n操作

    Python 整行读取文本方法并去掉readlines换行\n操作

    这篇文章主要介绍了Python 整行读取文本方法并去掉readlines换行\n操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • Python3实现从指定路径查找文件的方法

    Python3实现从指定路径查找文件的方法

    这篇文章主要介绍了Python3实现从指定路径查找文件的方法,涉及Python目录与文件的相关操作技巧,需要的朋友可以参考下
    2015-05-05
  • Pytorch实现逻辑回归分类

    Pytorch实现逻辑回归分类

    这篇文章主要为大家详细介绍了Pytorch实现逻辑回归分类,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-07-07

最新评论