PyCharm中Qt Designer+PyUIC配置

本文环境配置:

系统=>windows10:64位

语言=>Python:3.7.1

第三方库
PyQT5:5.11.3
pyqt5-tools:5.11.3.1.4

工具=>PyCharm:2018.3.1


使用PyCharm,根据不同的项目搭建独立的虚拟环境

  • 打开PyCharm
  • 点击New Project
  • 选择Pure Python,具体设置如下:

项目路径自定义
选择venv(virtualenv)目录,这里存放一个虚拟的python环境。这里所有的类库依赖都可以直接脱离系统安装的python独立运行。 
制定虚拟环境解释器以本地安装的哪个python版本来创建。

用同样的方法在创建一个GUI的项目。这样在我们的Project文件中就有两个文件夹,每一个文件夹对应一个项目。

不同的项目需要不同的第三方库。而PyCharm是根据项目来管理第三方库的安装。这样做的好处有很多。

python项目可以独立部署
防止一台服务器部署多个项目之间存在类库的版本依赖问题发生
也可以充分发挥项目的灵活性

在PyCharm中安装项目需要的包和插件

1、进入GUI项目,安装PyQt5和pyqt5-tools包

2、添加Qt Designer工具,Tools——External Tools——点击右侧的"+"

  • Name: 输入最后工具在菜单中的想呈现名称,比如我这里命名为QT Designer
  • Program: designer.exe程序的位置,位于当前项目文件\venv\Scripts\下。注意这里要先安装pyqt5-tools包,才有这个执行文件
  • Working directory:designer.exe工作路径,设置为$FileDir$

3、添加PyUIC工具,继续点击"+"

  • Name: 输入最后工具在菜单中的想呈现名称 PyUIC
  • Program:pyuic5.exe程序的位置,位于当前项目文件\venv\Scripts\下。注意这里要先安装PyQt5包,才有这个执行文件
  • Arguments: 执行语句$FileName$ -o $FileNameWithoutExtension$.py
  • Working dirctory: 工作路径$FileDir$

至此我们的GUI项目虚拟环境搭建完毕,下面来编写一点代码测试

首先使用手动编写一个登陆窗口

import sys
from PyQt5.QtWidgets import (QApplication, QWidget, QLabel,
                             QLineEdit, QMessageBox, QPushButton)
from PyQt5.QtCore import QCoreApplication

# 主窗体
app = QApplication(sys.argv)  # 创建应用对象
LoginWindow = QWidget()  # 构造登陆窗口
LoginWindow.setWindowTitle('登陆窗口')  # 窗口标题
LoginWindow.resize(300, 180)  # 窗口大小

# 姓名Label
name_Label = QLabel(LoginWindow)  # 放置在登陆窗口上
name_Label.setText('姓名')  # 设置显示文本
name_Label.move(60, 40)  # 设置位置

# 输入姓名文本框
name_Edit = QLineEdit(LoginWindow)  # 放置在登陆窗口上
name_Edit.move(100, 36)  # 设置位置

# 密码Label
pass_Label = QLabel(LoginWindow)  # 放置在登陆窗口上
pass_Label.setText('密码')  # 设置显示文本
pass_Label.move(60, 80)  # 设置位置

# 输入密码文本框
pass_Edit = QLineEdit(LoginWindow)  # 放置在登陆窗口上
pass_Edit.move(100, 76)  # 设置位置
pass_Edit.setEchoMode(QLineEdit.Password)  # 设置输入密码不可见


# 登陆函数
def end_event():
    if name_Edit.text() == "":
        QMessageBox.about(LoginWindow, '登陆', '请输入姓名')
    elif pass_Edit.text() == "":
        QMessageBox.about(LoginWindow, '登陆', '请输入密码')
    else:
        QMessageBox.about(LoginWindow, '登陆', name_Edit.text() + ' 欢迎登陆')


# 登陆按钮
end_Btn = QPushButton('登陆', LoginWindow)
end_Btn.clicked.connect(end_event)  # 绑定登陆函数
end_Btn.move(60, 120)

# 退出按钮
exit_Btn = QPushButton('退出', LoginWindow)
exit_Btn.clicked.connect(QCoreApplication.instance().quit)  # 绑定退出事件
exit_Btn.move(160, 120)

LoginWindow.show()  # 显示窗口
sys.exit(app.exec_())  # 进入消息循环

右键选择Run运行代码,一个简单的登陆窗口就制作完毕。

下面通过Qt Designer可视化排版制作窗体,看一下两者的区别

点击Tools——External Tools这里就有刚才添加的两个工具,选择Qt Designer

进入Qt Designer界面,选择Main Window,点击Create

在左侧有很多控件选项,在窗体上 添加以下控件,并设置属性:

两个Label控件来显示姓名和密码,并在右侧修改控件的objectName 
- 姓名标签:name_label 
- 密码标签:pass_label 
两个Line Edit控件来让用户输入单行文本,同样修改objectName属性,而其密码的输入框要设置不可见
- 姓名输入框:name_Edit
- 密码输入框:pass_Edit,修改echoMode属性为Password
两个Push Button控件让用户可以进行点击,修改objectName属性,
- 登陆按钮:end_Btn
- 退出按钮:exit_Btn

设置退出按钮的信号与槽

在右侧最下方选择Signal/Slot Editor
点击“+”号:
- Sender: 发送者 => 退出按钮 exit_Btn 
- Signal: 信号 => 单击 clicked 
- Receiver: 接受者 => 窗体 MainWindow 
- Slot: 槽 => 关闭事件 close

按Ctrl+R预览窗口,看是否是想要的界面。测试OK,保存文件到GUI项目下

回到PyCharm,在GUI项目下面有一个MainWindow.ui, 就是刚在使用Qt Designer保存的文件,现在需要将这个文件转换成.py文件

在该文件上点击右键,选择PyUIC

等程序运行完毕后,会多一个MainWindow.py的文件

里面已经帮我们编写了窗体的框架代码,但是这个文件无法运行,他只是定义了一个类。

新建一个Py文件,将这个窗体框架文件用import的方式导入进来,并编写如下代码

import sys
from PyQt5.QtWidgets import QApplication, QMainWindow,QMessageBox
from MainWindow import *

class MyWindow(QMainWindow,Ui_MainWindow):
    def __init__(self, parent=None):
        super(MyWindow, self).__init__(parent)
        self.setupUi(self)
        self.end_Btn.clicked.connect(self.end_event)  # 绑定登陆函数

    # 登陆函数
    def end_event(self):
        if self.name_Edit.text() == "":
            QMessageBox.about(self, '登陆', '请输入姓名')
        elif self.pass_Edit.text() == "":
            QMessageBox.about(self, '登陆', '请输入密码')
        else:
            QMessageBox.about(self, '登陆', self.name_Edit.text() + ' 欢迎登陆')

if __name__ == '__main__':
    app = QApplication(sys.argv)
    myWin = MyWindow()
    myWin.show()
    sys.exit(app.exec_())

右键运行,得到和我们手动编写一样的窗口。


对比两者的区别

手动编写的时候,需要大量的代码和运算来设置窗体中的控件属性以及大小位置等。

而使用Qt Designer来做,

  • 先通过可视化的排版。鼠标拖拽,点击就能很轻松的得到一个符合业务逻辑的窗体。
  • 然后使用PyUIC将.ui文件转换成.py
  • 最后新建一个文件,将创建好的窗体文件通过import的方式导入即可
  • 这样的好处是将业务逻辑代码和窗体代码分离。将主要精力放在业务逻辑上,而不是在美化窗体。
posted @ 2019-08-23 14:25  不夜男人  阅读(1305)  评论(0编辑  收藏  举报