当前位置:   article > 正文

我与PyQt5有个约会系列教程(1): 从零开始 学习PyQt5_build 201.7846.77

build 201.7846.77

PyQt5 是用来创建Python GUI应用程序的工具包。作为一个跨平台的工具包,PyQt可以在所有主流操作系统上运行(Unix,Windows,Mac)。

PyQt5是基于Digia公司强大的图形程式框架Qt5的python接口,由一组python模块构成。PyQt5本身拥有超过620个类和6000函数及方法。

本文描述Windows系统下如何安装Python + PyCharm + PyQt5,并通过PyQt5 采用 两种方式设计GUI界面。a.直接使用代码设计界面;b. 先使用QtDesigner进行可视化设计,然后将生成的.ui文件转换成.py文件。

安装Python + PyCharm + PyQt5

1、安装Python

访问官网https://www.python.org/,下载并安装你的目标Python版本。

我安装的版本是Python 3.7.3。

2、安装PyQt5

1)进入cmd界面。执行命令 pip install pyqt5 pyqt5-tools ,等待一会儿,命令执行完毕后PyQt5就安装好了。

2)在cmd界面中输入 pip list,确认一下pyqt5, pyqt5-tools包是否已安装成功。

3、安装PyCharm

1)访问官网http://www.jetbrains.com/pycharm/download/#section=windows  作者选择下载并安装Community版本 ——目前是

  • Version: 2020.1.2
  • Build: 201.7846.77
  • 3 June 2020

2)PyCharm 基本配置:

a. 建立一个新项目。 

b.设置默认PyCharm解析器

选择File | Settings | Project | Project Interpreter,设置 Project Interpreter为你使用的python版本

例如 C:\Python37\python.exe

c. 添加第三方库 

 停留在 Project Interpreter 界面,点击+,查找并安装 pyqt5,pyqt5-sip ,pyqt5-tools 。安装成功后返回,界面应该如下

d.配置PyQt

PyCharm中选择File | Settings | Tools | External Tools,点击新建工具, 建立QTdesigner 和 PyUIC工具

1), QTdesigner:

配置两个关键参数:

Program:自己的designer.exe路径 例如 C:\Python37\Lib\site-packages\pyqt5_tools\Qt\bin\designer.exe  

Working directory:$FileDir$

2), PyUIC:

配置三个关键参数:

Program:自己的python.exe路径 例如 C:\Python37\python.exe

Arguments:-m PyQt5.uic.pyuic $FileName$ -o $FileNameWithoutExtension$.py

Working directory:$FileDir$

工具建立成功后返回ExternalTools界面,如下:

4、PyCharm中通过PyQt5设计GUI界面

1)利用代码创建GUI界面

新建MyFirstGUI.py,输入如下代码 :

  1. # -*- coding: utf-8 -*-
  2. """第一个程序"""
  3. from PyQt5.QtWidgets import QApplication, QWidget     # 导入PyQt5部件
  4. import sys
  5. app = QApplication(sys.argv)  # 建立application对象
  6. qwidget = QWidget()  # 建立窗体对象
  7. qwidget.resize(400, 300)  # 设置窗体大小
  8. qwidget.setWindowTitle("我的第一个pyqt程序")  # 设置窗体标题
  9. qwidget.show()  # 显示窗体
  10. sys.exit(app.exec())  # 运行程序


选择Run->Run MyFirstGUI,结果显示如下界面就成功了。

2)利用QT Designer代码生成一个GUI界面 ,并用PyUIC转换为.py文件。

选择Tools->ExternalTools->QTdesigner,进入QT Designer界面,第一次会弹出一个GUI创建界面,点击creat 自动生成一个带下方按钮的GUI界面,如下图。

另存该界面为Utitled.ui文件。

返回PyCharm 项目界面,项目列表下多出了这个.ui文件

右键单击Utitled.ui,弹出列表中选择ExternalTools->PyUIC 就会生成Utitled.ui对应的Utitled.py文件了。

内容如下 : 

  1. # -*- coding: utf-8 -*-
  2. # Form implementation generated from reading ui file 'untitled.ui'
  3. #
  4. # Created by: PyQt5 UI code generator 5.13.0
  5. #
  6. # WARNING! All changes made in this file will be lost!
  7. from PyQt5 import QtCore, QtGui, QtWidgets
  8. class Ui_Dialog(object):
  9. def setupUi(self, Dialog):
  10. Dialog.setObjectName("Dialog")
  11. Dialog.resize(400, 300)
  12. self.buttonBox = QtWidgets.QDialogButtonBox(Dialog)
  13. self.buttonBox.setGeometry(QtCore.QRect(30, 240, 341, 32))
  14. self.buttonBox.setOrientation(QtCore.Qt.Horizontal)
  15. self.buttonBox.setStandardButtons(QtWidgets.QDialogButtonBox.Cancel|QtWidgets.QDialogButtonBox.Ok)
  16. self.buttonBox.setObjectName("buttonBox")
  17. self.retranslateUi(Dialog)
  18. self.buttonBox.accepted.connect(Dialog.accept)
  19. self.buttonBox.rejected.connect(Dialog.reject)
  20. QtCore.QMetaObject.connectSlotsByName(Dialog)
  21. def retranslateUi(self, Dialog):
  22. _translate = QtCore.QCoreApplication.translate
  23. Dialog.setWindowTitle(_translate("Dialog", "Dialog"))

上面的代码仅仅是界面的代码,运行时并不能有界面显示出来。

还需要增加一些代码,才可以让界面显示出来。

  1. import sys
  2. from PyQt5.QtWidgets import QApplication, QMainWindow
  3. if __name__ == '__main__':
  4. app = QApplication(sys.argv)
  5. MainWindow = QMainWindow()
  6. ui = Ui_Dialog()
  7. ui.setupUi(MainWindow)
  8. MainWindow.show()
  9. sys.exit(app.exec_())

完整的代码如下 : 

  1. # -*- coding: utf-8 -*-
  2. # Form implementation generated from reading ui file 'untitled.ui'
  3. #
  4. # Created by: PyQt5 UI code generator 5.13.0
  5. #
  6. # WARNING! All changes made in this file will be lost!
  7. from PyQt5 import QtCore, QtGui, QtWidgets
  8. class Ui_Dialog(object):
  9. def setupUi(self, Dialog):
  10. Dialog.setObjectName("Dialog")
  11. Dialog.resize(400, 300)
  12. self.buttonBox = QtWidgets.QDialogButtonBox(Dialog)
  13. self.buttonBox.setGeometry(QtCore.QRect(30, 240, 341, 32))
  14. self.buttonBox.setOrientation(QtCore.Qt.Horizontal)
  15. self.buttonBox.setStandardButtons(QtWidgets.QDialogButtonBox.Cancel|QtWidgets.QDialogButtonBox.Ok)
  16. self.buttonBox.setObjectName("buttonBox")
  17. self.retranslateUi(Dialog)
  18. self.buttonBox.accepted.connect(self.accept)
  19. self.buttonBox.rejected.connect(self.reject)
  20. QtCore.QMetaObject.connectSlotsByName(Dialog)
  21. def accept(self):
  22. print("Dialog.accept")
  23. def reject(self):
  24. print("Dialog.reject")
  25. def retranslateUi(self, Dialog):
  26. _translate = QtCore.QCoreApplication.translate
  27. Dialog.setWindowTitle(_translate("Dialog", "Dialog"))
  28. import sys
  29. from PyQt5.QtWidgets import QApplication, QMainWindow
  30. if __name__ == '__main__':
  31. app = QApplication(sys.argv)
  32. MainWindow = QMainWindow()
  33. ui = Ui_Dialog()
  34. ui.setupUi(MainWindow)
  35. MainWindow.show()
  36. sys.exit(app.exec_())

 

运行出来的界面如下:

今天就到这,谢谢大家阅读,如有问题,请留言。

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/663086
推荐阅读
相关标签
  

闽ICP备14008679号