PYQT的开发总结(Ui,数据库,信号

这一两个月一直在搞研究所交付的任务,开发一个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提供的接口。下一篇,详细介绍我自己对数据库的封装(建库,见表,链接初始化 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值