这一两个月一直在搞研究所交付的任务,开发一个pyqt的客户端工具。我主要负责UI开发,数据库搭建和使用,界面跳转和信号传递信息。因为没有接触过,所有是边学边开发,因为是涉及到研究中心的项目,无法完全展示代码
1.主要使用的开发工具:PyCharm2018,MySQL,Eric6,Qt Designer
2.开发的客户端工具的用途:通过串口或者网络,智能控制和查看电力空气开关的平台
3.Qt Designer方便我们实现界面的开发,但依旧要了解其生成的文件的内容。一般来说是先定义控件,位置摆放,,控件命名
self.layoutWidget = QtWidgets.QWidget(Dialog_cx_zdip)
self.layoutWidget.setGeometry(QtCore.QRect(170, 440, 295, 30))
self.layoutWidget.setObjectName("layoutWidget")
4.Eric6是将界面的.qt文件编译成.py文件,提供给pycharm使用。
5.方便开发,ui文件和logic文件是分开的。
6.在logic文件中,
先是初始化
def __init__(self, parent=None):
super(MainWindow, self).__init__(parent)
self.setupUi(self)
# 在主窗口类的初始化函数中对子窗口进行实例化如果在其他函数中实例化子窗口
# 可能会出现子窗口闪退的问题
# self.xt_txxz = Dialog_xt_txxz(self)
修饰信号器,自定义信号(两种信号
# 定义信号
_signal = pyqtSignal(str)
# 信号修饰器,右击菜单的增加函数,给listwidget增加内容行
@pyqtSlot()
def on_action_zj_triggered(self):
# 实例化子窗口的对象
self.list_add = Dialog_list_add(self)
self.list_add.setWindowTitle('增加终端')
# 给主窗口绑定信号和槽函数
self.list_add._signal.connect(self.getData)
self.list_add.exec()
# 响应子窗口发来的信号的槽函数,实现子窗口的内容加入主窗口和数据库
def getData(self, list_item):
# 把子窗口传来的参数,给主窗口
self.listWidget.addItem(list_item)
# 把内容写入数据库
sql = "insert into zd(zdlb)values (%s)"
sqlHelper.execute(sql, list_item)
if __name__模块
if __name__ == "__main__":
import sys
# 实例一个线程,为了让窗口一直挂着
app = QApplication(sys.argv)
# 实例化该类的对象
ui = MainWindow()
# 实例化数据库类的对象
sqlHelper = MysqlHelper('localhost', '用户名', '密码', 'kongqikaiguan', 3306, 'utf8')
# 查询数据库
sql = "select zdlb from zd"
result = sqlHelper.select_all(sql)
# for循环取出组元中的元素,并展示出来
for row in result:
for line in row:
ui.listWidget.addItem(str(line))
# 把主窗口展示出来
ui.show()
# 把程序一直exec挂着运行,直到结束exit
sys.exit(app.exec_())
7.数据库链接用的是pymysql提供的接口。下一篇,详细介绍我自己对数据库的封装(建库,见表,链接初始化