且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

更新时间:2022-02-14 08:45:02

一、使用qt designer拖拽界面。

使用qtdesigner拖拽界面:

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

如图左侧导航栏,1:Sources,2:Forms,3:Resouces

1:代码,2:Qt Designer的拖拽界面的代码,xml形式的 3:暂未使用,猜测用来放置一些图片、音频、视频之类的。

 

在2:Forms中右键点击,然后选择new form,选择 类型:Dialog然后会启动Qt Designer,拖拽出如图的界面。

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

 

二、在qt designer中  自定义信号/槽

在Qt Designer的界面中

1:编辑窗口组件,2:编辑信号/槽

点击2,(注:初次操作生成界面时,自定义编辑信号/槽的步骤请跳过,否则界面无法生成对应的py代码。)

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

点击编辑后

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

图中灰色的全是组件默认就有的槽,黑色的是自己定义的,自定义get_text()后。

在配置连接的弹框中选择左侧的clicked()与右侧的get_text()然后点击OK。

在右下角的位置将可以看见多出一行,如图:

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

然后保存Qt Designer的界面,关闭不关闭皆可。

注:在生成Qt Designer界面对应的py代码前一定不要写自定义的信号/槽,否则会无法生成界面对应的py代码的。

 

三、生成py代码并显示界面。

回到Eric6中的Forms,右击刚才创建的form

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

 

点击1,Compile form然后可以看到

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

然后就在Source下可以看到多出一个文件:Ui_main.py

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

 

然后再回到Forms下右击main.ui选择Generate Dialog Code...

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

点击New... 

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

注:Classname和Filename全是自动生成,算是默认值吧,点击OK。

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

继续点击OK,会在Sources中发现多了个main.py文件。

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

双击main.py

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

注意双下划线出的 .Ui_main的"."要去掉。

然后点击F2

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

是不是和想要的界面没出现,感觉不爽?

呵呵,没事,因为上边的代码不会自动执行所以什么都没出来。

在最下边加入如下代码

if __name__ == '__main__':

    import sys
    from PyQt5.QtWidgets import  QApplication
    app = QApplication(sys.argv)
    window = Dialog()  ### Dialog是main.py的上部的Class的名字
    window.show()
    sys.exit(app.exec_())

 注意,这些代码不用被包在class里边了。

再点击F2,就可以看见想要的界面了。

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

看见想要的界面出来了,小开心有木有。

 

四、实现自定义的信号/槽中的槽。

 

如果在生成Qt designer的界面的py代码前自定义了信号/槽,则会在Generate Dialog Code...时提示error,其中get_text()是自定义的槽。

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

如果生成界面的py代码前自定义了信号/槽,并在Generate Dialog Code...时提示如图的error,回到Qt Designer中的右下角

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

删除掉信号/槽的绑定就行。然后继续执行步骤3。

 

执行步骤2,绑定信号/槽,绑定按钮的点击事件到主框的自定义的函数:get_text()。

在main.py的class Dialog中增加自定义函数

    def get_text(self):
        print('get_text')
        print(self.textEdit.toPlainText()) ##获取文本的内容。。。该函数也是百度查的,菜鸟一枚,大家理解哈。

 再次执行步骤2,仍会提示没有get_text属性,忽略它就好继续执行,此时界面对应的py代码类已经存在了,不需要再次new了,直接生成就好。

 

F2执行main.py代码,点击绑定信号/槽的那个按钮

Py3+PyQt5+Eric6:学习记录之第一天:点击按钮获取文本框的值并输出。

点击按钮后打印文本框的内容,小开心有木有。

 

五、个人理解:

上代码,全部的main.py的代码也是自动生成就下边几行代码是自己手动添加的、出处也是网上查的,Qt Designer界面自动生成的代码就不上了,如下。

# -*- coding: utf-8 -*-

"""
Module implementing Dialog.
"""

from PyQt5.QtCore import pyqtSlot
from PyQt5.QtWidgets import QDialog

from Ui_main import Ui_Dialog


class Dialog(QDialog, Ui_Dialog):
    """
    Class documentation goes here.
    """
    def __init__(self, parent=None):
        """
        Constructor
        
        @param parent reference to the parent widget (QWidget)
        """
        super(Dialog, self).__init__(parent)
        self.setupUi(self) ## 调用Qt Designer界面生成的代码的布局函数,同时将自身以参数的形式传递过去,然后就可以调用本类Dialog的函数。
        
    def get_text(self):
        print('get_text')
        print(self.textEdit.toPlainText())  ##可以直接调用父类的属性,这个不错,以后信号/槽  神马的全都写到单独的类中,然后继承界面的类,不错不错。


if __name__ == '__main__':

    import sys
    from PyQt5.QtWidgets import  QApplication
    app = QApplication(sys.argv)
    window = Dialog() ## 类名,注意要和自己定义的类名一致。
    window.show()
    sys.exit(app.exec_())