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

简介: 一、使用qt designer拖拽界面。 使用qtdesigner拖拽界面: 如图左侧导航栏,1:Sources,2:Forms,3:Resouces 1:代码,2:Qt Designer的拖拽界面的代码,xml形式的 3:暂未使用,猜测用来放置一些图片、音频、视频之类的。

一、使用qt designer拖拽界面。

使用qtdesigner拖拽界面:

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

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

 

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

 

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

在Qt Designer的界面中

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

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

点击编辑后

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

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

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

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

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

 

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

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

 

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

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

 

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

点击New... 

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

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

双击main.py

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

然后点击F2

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

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

在最下边加入如下代码

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,就可以看见想要的界面了。

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

 

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

 

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

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

删除掉信号/槽的绑定就行。然后继续执行步骤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代码,点击绑定信号/槽的那个按钮

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

 

五、个人理解:

上代码,全部的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_())

 

相关文章
|
8月前
|
算法 定位技术 C语言
【python实操】软件安装进展提示进度条如何实现的?如何设置窗体拉伸?如何获取输入框内容?
【python实操】软件安装进展提示进度条如何实现的?如何设置窗体拉伸?如何获取输入框内容?
101 0
|
Python
Pyside6-第一篇-创建第一个窗口
Pyside6-第一篇-创建第一个窗口
382 0
|
8月前
|
Python
python tkinter 界面倒计时(用于监督页面返回)
python tkinter 界面倒计时(用于监督页面返回)
python tkinter 界面倒计时(用于监督页面返回)
|
程序员 C# 索引
C#之二十 Win Form对话框
C#之二十 Win Form对话框
95 0
《QT从基础到进阶·二十四》按钮组QButtonGroup,单选框QRadioButton和多选框QCheckBox
《QT从基础到进阶·二十四》按钮组QButtonGroup,单选框QRadioButton和多选框QCheckBox
447 0
《QT从基础到进阶·二十三》弹窗提示框QMessageBox和QCloseEvent事件
《QT从基础到进阶·二十三》弹窗提示框QMessageBox和QCloseEvent事件
566 0
|
Linux iOS开发 MacOS
[学习][笔记] qt5 从入门到入坟:<六>对话框
[学习][笔记] qt5 从入门到入坟:<六>对话框
|
JavaScript
js限制文字字数--点击展开点击收起demo效果示例(整理)
js限制文字字数--点击展开点击收起demo效果示例(整理)
|
前端开发 C语言 C++
Python Tkinter Gui 窗口图标,标签,输入,单复选,文件导入,按钮,日志 等常用组件 基本使用
tkinter是什么? 我们编写的Python代码会调用内置的Tkinter,Tkinter封装了访问Tk的接口; Tk是一个图形库,支持多个操作系统,使用Tcl语言开发; Tk会调用操作系统提供的本地GUI接口,完成最终的GUI;
1292 0
Python Tkinter Gui 窗口图标,标签,输入,单复选,文件导入,按钮,日志 等常用组件 基本使用