【引子】
在PyQt5自带教程中,地址簿(address book)程序没有完全实现界面与业务逻辑分离。
本文我打算用eric6+PyQt5对其进行改写,以实现界面与逻辑完全分离。
【概览】
1、界面: 2、功能简介: 程序有三种操作模式:浏览模式、添加模式、编辑模式。 其实现的功能都显式的体现在各个按钮上 3、主要步骤: 1)、在eric6中新建项目,新建窗体,取名为 addressbook.ui 文件 2)、(自动打开)进入PyQt5 Desinger,编辑图形界面,保存 3)、回到eric 6,对上一步得到的界面文件 addressbook.ui 文件右击,编译窗体,得到 Ui_addressbook.py 文件 4)、然后再对 addressbook.ui 文件右击,生成对话框代码,得到 addressbook.py 文件。(在addressbook.py中添加自己的程序逻辑) 5)、py2exe打包成exe文件(此步略) 4、涉及的知识点: import sys, pickle from PyQt5.QtCore import pyqtSlot, QFile, QIODevice, Qt, QTextStream from PyQt5.QtWidgets import QWidget, QDialog, QLabel, QLineEdit, QPushButton, QHBoxLayout, QMessageBox,QFileDialog, QApplication【正文】1、一般的步骤省略不表,接上面主要步骤第二步:在Qt设计师中,将行编辑框(lineEdit)、文本编辑框(textEdit)、及十一个按钮(pushButton)的对象名(objectName)分别设置如下:
lineEdit_name(姓名输入框)
textEdit_address(地址输入框)
pushButton_add(添加 按钮)
pushButton_edit(编辑 按钮)
pushButton_remove(删除 按钮)
pushButton_find(查找 按钮)
pushButton_submit(提交 按钮)
pushButton_cancel(取消 按钮)
pushButton_load(导入 按钮)
pushButton_save(保存 按钮)
pushButton_export(导出 按钮)
pushButton_previous(前一个 按钮)
pushButton_next(后一个 按钮)
2、关闭Qt设计师,回到eric6
先右击addressbook.ui 文件,编译窗体,得到 Ui_addressbook.py 文件
然后再次右击addressbook.ui 文件,生成对话框代码,
在弹窗中勾选十一个按钮的 on_x_clicked() 事件,确定,得到 addressbook.py 文件。
3、对addressbook.py 文件执行下面四步处理:
1)、清空所有注释
2)、去掉一个多余的点,将
from .Ui_addressbook import Ui_Form
变成:
from Ui_addressbook import Ui_Form
3)、将所有clicked()下的代码改写为pass
@pyqtSlot() def on_pushButton_add_clicked(self): pass @pyqtSlot() def on_pushButton_edit_clicked(self): pass # ...
4)、在 addressbook.py 文件最后面加上下面几句代码:
if __name__ == '__main__': import sys from PyQt5.QtWidgets import QApplication app = QApplication(sys.argv) dlg = Dialog() dlg.show() sys.exit(app.exec_())
最后,addressbook.py 看起来是这个样子:
4、下面添加逻辑代码
5、程序运行界面