【PyQt】13-对话框

文章目录

  • 前言
  • 一、知识储备
  • 二、详细展开
    • 2.1 通用对话框-QDialog
    • 2.1 消息类型对话框-QMessageBox
      • 运行结果
    • 2.2 输入对话框 QInputDilog
      • 运行结果
    • 2.3 字体对话框-QFontDialog
      • 运行结果
    • 2.4 颜色对话框
      • 运行结果
    • 2.5 文件对话框
      • 运行结果
  • 总结


前言

1、四种形式的对话框。
2、警告框的制作。
3、修改字体框。
4、学会查看函数的返回值。


一、知识储备

对话框的基类是QDialog

  • QMessageBox
    可以用来显示各种类型的消息框,包括提示、警告、错误和提问等。可以包含文本信息、按钮和图标,用于与用户进行交互。

  • QColorDialog用于选择颜色的对话框,可以让用户选择颜色并返回所选颜色的数值。

  • QFileDialog 用于显示文件选择对话框或目录选择对话框,用于让用户选择文件或目录。

  • QFontDialog用于选择字体的对话框,可以让用户选择字体样式、大小和颜色等属性。

  • QInputDialog提供了多种标准的对话框,用于获取不同类型的用户输入,如文本、整数、浮点数等。

二、详细展开

2.1 通用对话框-QDialog

'''
#Author :susocool
#Creattime:2024/2/15
#FileName:30-通用对话框
#Description: 

'''
import sys
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *

class QDialogDemo(QMainWindow):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.setWindowTitle('通用对话框')
        self.resize(300,200)

        self.button = QPushButton(self)
        self.button.setText('弹出对话框')
        
        self.button.clicked.connect(self.showDialog)

    def showDialog(self):
        dialog = QDialog()
        
        button = QPushButton('确定',dialog)
        button.clicked.connect(dialog.close)
        button.move(50,50)
        
        dialog.setWindowTitle('对话框')
        dialog.setWindowModality(Qt.ApplicationModal)

        dialog.exec()

if __name__ == '__main__':
    app = QApplication(sys.argv)
    ui = QDialogDemo()
    ui.show()
    sys.exit(app.exec_())

运行结果
加粗样式

2.1 消息类型对话框-QMessageBox

1.关于对话框
2.错误对话框
3.警告对话框
4.提问对话框
5.消息对话框

'''
#Author :susocool
#Creattime:2024/2/15
#FileName:31-消息类型
#Description: 展示5种消息类型
'''
import sys
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *

class MessaageBoxDemo(QWidget):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.setWindowTitle('消息类型展示')
        self.resize(300,250)

        self.button_show = QPushButton()
        self.button_show.setText('显示对话框')
        self.button_showMessage = QPushButton('显示消息')
        self.button_showWarnning = QPushButton('显示警告')
        self.button_showError = QPushButton('显示错误')
        self.button_showAsk = QPushButton('显示提问')


        self.button_show.clicked.connect(self.showDialog)
        self.button_showMessage.clicked.connect(self.showDialog)
        self.button_showError.clicked.connect(self.showDialog)
        self.button_showWarnning.clicked.connect(self.showDialog)
        self.button_showAsk.clicked.connect(self.showDialog)


        layout = QVBoxLayout()
        layout.addWidget(self.button_show)
        layout.addWidget(self.button_showMessage)
        layout.addWidget(self.button_showError)
        layout.addWidget(self.button_showWarnning)
        layout.addWidget(self.button_showAsk)
        self.setLayout(layout)

    def showDialog(self):
        text = self.sender().text()
        if text == '显示对话框':
            QMessageBox.about(self,'关于','这是一个关于对话框')
        elif text == '显示消息':
            reply = QMessageBox.information(self,'消息','这是一个显示消息对话框',QMessageBox.Yes | QMessageBox.No,QMessageBox.Yes)
            # print(reply)
        elif text == '显示警告':
            # 注意是小写的w
            QMessageBox.warning(self,'警告','这是一个警告对话框',QMessageBox.Yes | QMessageBox.No,QMessageBox.Yes)
        elif text == '显示错误':
            QMessageBox.critical(self,'错误','这是一个错误对话框',QMessageBox.Yes | QMessageBox.No,QMessageBox.Yes)
        elif text == '显示提问':
            QMessageBox.question(self,'提问','这是一个提问对话框',QMessageBox.Yes | QMessageBox.No,QMessageBox.Yes)


if __name__ == '__main__':
    app = QApplication(sys.argv)
    ui = MessaageBoxDemo()
    ui.show()
    sys.exit(app.exec_())

运行结果

关于
在这里插入图片描述
消息
在这里插入图片描述
错误
在这里插入图片描述
警告
在这里插入图片描述
提问
在这里插入图片描述

2.2 输入对话框 QInputDilog

  • QInputDilog.getItem
  • QInputDialog.getText
  • QInputDialog.getInt
'''
#Author :susocool
#Creattime:2024/2/15
#FileName:32-输入对话框
#Description: 

'''
import sys
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *

class MessaageBoxDemo(QWidget):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.setWindowTitle('输入对话框')
        self.button_1 = QPushButton('获取列表中的选项')
        self.lineEdit_1 = QLineEdit()
        self.button_2 = QPushButton('获取字符串')
        self.lineEdit_2 = QLineEdit()
        self.button_3 = QPushButton('获取整数')
        self.lineEdit_3 = QLineEdit()

        self.button_1.clicked.connect(self.getItem)
        self.button_2.clicked.connect(self.getText)
        self.button_3.clicked.connect(self.getInt)


        layout = QFormLayout()
        layout.addRow(self.button_1,self.lineEdit_1)
        layout.addRow(self.button_2,self.lineEdit_2)
        layout.addRow(self.button_3,self.lineEdit_3)
        self.setLayout(layout)

    def getItem(self):
        items = ('C','C++','Python','Java')
        item,ok = QInputDialog.getItem(self,'请选择编程语言','语言列表',items)
        if ok and items:
            self.lineEdit_1.setText(item)

    def getText(self):
        text,ok = QInputDialog.getText(self,'文本输入框','输入姓名')
        if ok and text:
            self.lineEdit_2.setText(text)

    def getInt(self):
        num,ok = QInputDialog.getText(self,'整数输入框','输入数字')
        if ok and num:
            self.lineEdit_3.setText(str(num))


if __name__ == '__main__':
    app = QApplication(sys.argv)
    ui = MessaageBoxDemo()
    ui.show()
    sys.exit(app.exec_())

运行结果

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.3 字体对话框-QFontDialog

'''
#Author :susocool
#Creattime:2024/2/16
#FileName:33-字体对话框
#Description:修改字体
'''
import sys
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *

class QFontDialogDemo(QWidget):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.setWindowTitle('字体对话框')
        self.button_font = QPushButton('选择字体')

        self.label_font = QLabel('未经反思的人生是不值得过的,未经记录的技术是不负责任的')


        self.button_font.clicked.connect(self.getFont)

        layout = QVBoxLayout()
        layout.addWidget(self.button_font)
        layout.addWidget(self.label_font)
        self.setLayout(layout)

    def getFont(self):
        font,ok = QFontDialog.getFont()
        if ok :
            self.label_font.setFont(font)

if __name__ == '__main__':
    app = QApplication(sys.argv)
    ui = QFontDialogDemo()
    ui.show()
    sys.exit(app.exec_())

在这里插入图片描述
关于,为什么要设置两个参数去接收。

    def getFont(self, *__args): # real signature unknown; restored from __doc__ with multiple overloads
        """
        getFont(initial: QFont, parent: Optional[QWidget] = None, caption: Optional[str] = '', options: Union[QFontDialog.FontDialogOptions, QFontDialog.FontDialogOption] = QFontDialog.FontDialogOptions()) -> (QFont, Optional[bool])
        getFont(parent: Optional[QWidget] = None) -> (QFont, Optional[bool])
        """
        pass
  • 第一个重载的签名为 getFont(initial: QFont, parent: Optional[QWidget] = None, caption: Optional[str] = ‘’, options: Union[QFontDialog.FontDialogOptions, QFontDialog.FontDialogOption] = QFontDialog.FontDialogOptions()) -> (QFont, Optional[bool])
  • 第二个重载的签名为 getFont(parent: Optional[QWidget] = None) -> (QFont, Optional[bool])

这两个方法都返回一个元组,元组的第一个元素是 QFont 对象,第二个元素是一个可选的布尔值。

简单说,就是因为QFontDialog.getFont()的返回值时两个,所以就要设置两个变量来接收。

运行结果

在这里插入图片描述
在这里插入图片描述

2.4 颜色对话框

'''
#Author :susocool
#Creattime:2024/2/16
#FileName:34-颜色对话框
#Description: 

'''
import sys
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *

class QColorDialogDemo(QWidget):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.setWindowTitle('颜色调节')
        self.button_color = QPushButton( '选择字体颜色' )

        self.label_color = QLabel( '未经反思的人生是不值得过的,未经记录的技术是不负责任的' )


        self.button_color.clicked.connect( self.getColor )

        layout = QVBoxLayout()
        layout.addWidget( self.button_color )
        layout.addWidget( self.label_color )
        self.setLayout(layout)

    def getColor(self):
        color = QColorDialog.getColor()
        p = QPalette()
        p.setColor(QPalette.windowText,color)
        self.label_color.setPalette(p)

if __name__ == '__main__':
    app = QApplication(sys.argv)
    ui = QColorDialogDemo()
    ui.show()
    sys.exit(app.exec_())

查看返回值
在这里插入图片描述

运行结果

在这里插入图片描述
但是选择完字体之后会异常退出。目前尚未查明原因QAQ
在这里插入图片描述

背景色
在这里插入图片描述

2.5 文件对话框

打开,保存文件

'''
#Author :susocool
#Creattime:2024/2/16
#FileName:35-文件对话框
#Description: 打开、保存文件
'''

import sys
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *

class QFileDialogDemo(QWidget):
    def __init__(self):
        super().__init__()
        self.initUI()

    def initUI(self):
        self.setWindowTitle('文件操作')
        self.button_img = QPushButton( '加载图片' )
        self.label_showimg = QLabel()
        self.button_file = QPushButton('加载文件')
        self.contents = QTextEdit()

        self.button_img.clicked.connect(self.loadimg)
        self.button_file.clicked.connect(self.loadfile)

        layout = QVBoxLayout()
        layout.addWidget(self.button_img)
        layout.addWidget(self.label_showimg)
        layout.addWidget(self.button_file)
        layout.addWidget(self.contents)
        self.setLayout(layout)

    def loadimg(self):
        fname,_ = QFileDialog.getOpenFileName(self,'打开文件','.','图像文件(*.jpg *,png)')
        self.label_showimg.setPixmap(QPixmap(fname))

    def loadfile(self) :
        dialog = QFileDialog ()
        dialog.setFileMode ( QFileDialog.AnyFile )  # 选择任意类型的文件
        dialog.setFilter ( QDir.Files ) # 设置对话框的过滤器,限制用户只能选择文件,而不是目录
        if dialog.exec () :
            filenames = dialog.selectedFiles ()
            # f = open ( filenames[0], 'r' )      # 可以打开多个,只展示第一个
            f = open ( filenames[0],encoding='utf-8', mode='r' )      # 对编码进行限制之后可以显示的类型更多
            with f :
                date = f.read ()
                self.contents.setText ( date )  # 显示文件内容到 self.contents 控件上
""" 
# 将函数设置为空
    def loadfile(self):
        pass

"""

if __name__ == '__main__':
    app = QApplication(sys.argv)
    ui = QFileDialogDemo()
    ui.show()
    sys.exit(app.exec_())

运行结果

在这里插入图片描述
在这里插入图片描述


总结

这篇文章依旧没有总结

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/389646.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【从Python基础到深度学习】 8. VIM两种状态

一、安装 sudo apt install vim 二、VIM两种模式 - 命令状态/编辑状态 1.1 进入/退出VIM 进入VIM vim 退出vim :q <enter> 2.2 根目录下添加配置文件 window下创建vimrc类型文件内容如下&#xff1a; set nu set cursorline set hlsearch set tabstop4 使用Wins…

MySQL 基础知识(一)之数据库和 SQL 概述

目录 1 数据库相关概念 2 数据库的结构 ​3 SQL 概要 4 SQL 的基本书写规则 1 数据库相关概念 数据库是将大量的数据保存起来&#xff0c;通过计算机加工而成的可以进行高效访问的数据集合数据库管理系统&#xff08;DBMS&#xff09;是用来管理数据库的计算机系统&#xf…

QObject 的拷贝构造和赋值操作

QObject中没有提供一个拷贝构造函数和赋值操作符给外界使用&#xff0c;其实拷贝构造和赋值的操作都是已经声明了的&#xff0c;但是它们被使用了Q_DISABLE_COPY () 宏放在了private区域。因此所有继承自QObject的类都使用这个宏声明了他们的拷贝构造函数和赋值操作符为私有。 …

软件测试【四】Python复杂操作

一、Python中的数据类型:元组在python中的应用 在Python中&#xff0c;元组是一种不可变的数据类型&#xff0c;它和列表类似&#xff0c;但是元组创建后就不能被修改。元组使用小括号 () 来表示&#xff0c;其中的元素用逗号隔开。 元组在Python中的应用非常广泛&#xff0c…

Spring Boot 笔记 020 redis集成

1.1 安装redis Windows 下 Redis 安装与配置 教程_redis windows-CSDN博客 2.1 引入redis坐标 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency> 2.2 配置…

【前端高频面试题--Vue生命周期篇】

&#x1f680; 作者 &#xff1a;“码上有前” &#x1f680; 文章简介 &#xff1a;前端高频面试题 &#x1f680; 欢迎小伙伴们 点赞&#x1f44d;、收藏⭐、留言&#x1f4ac;前端高频面试题--Vue生命周期篇 往期精彩内容Vue的生命周期Vue子组件和父组件执行顺序在哪个生命周…

协调尺度:特征缩放在机器学习中的重要作用

目录 一、介绍 二、背景知识 三、了解功能缩放 四、特征缩放方法 五、特征缩放的重要性 六、实际意义 七、代码 八、结论 一、介绍 特征缩放是机器学习和数据分析预处理阶段的关键步骤&#xff0c;在优化各种算法的性能和效率方面起着至关重要的作用。本文深入探讨了特征缩放的…

【论文精读】DALL·E

摘要 本文利用从互联网上收集的2.5亿个图像/文本对数据&#xff0c;训练了一个120亿参数的自回归transformer&#xff0c;进而得到一个可以通过自然语言/图像控制生成的高保真图像生成模型。在大多数数据集上的表现超越以往的方法。 框架 本文的目标为通过训练一个自回归trans…

结构体对齐规则及为什么会有结构体对齐

前言&#xff1a; 大家在学习结构体中&#xff0c;在计算结构体大小时想必会很疑惑&#xff0c;为什么结构体的大小不是按照常理像数组一样一个字节一个字节的挨在一起放&#xff1f;今天带大家一起深入探讨一下背后的规则和原因。 结构体对齐规则&#xff1a; 结构体对齐其实…

BUUCTF misc 专题(47)[SWPU2019]神奇的二维码

下载附件&#xff0c;得到一张二维码图片&#xff0c;并用工具扫描&#xff08;因为图片违规了&#xff0c;所以就不放了哈。工具的话&#xff0c;一般的二维码扫描都可以&#xff09; swpuctf{flag_is_not_here}&#xff0c;&#xff08;刚开始出了点小差错对不住各位师傅&am…

进程间通信——管道

文章目录 进程间通信的介绍进程间通信的目的进程间通信的本质 匿名管道创建管道匿名管道的特征 命名管道小结 进程间通信的介绍 进程间通信简称IPC&#xff08;Interprocess communication&#xff09;&#xff0c;进程间通信就是在不同进程之间传播或交换信息。 进程间通信的…

分布式文件系统 SpringBoot+FastDFS+Vue.js【三】

分布式文件系统 SpringBootFastDFSVue.js【三】 七、创建后台--分角色管理7.1.创建后台数据库表7.2.创建实体类7.2.1.Admin7.2.2.Menu7.2.3.MenuBean7.2.4.Role7.2.5.RoleMenu 7.3.编辑配置文件application.yml7.4.编写工具类7.4.1.AuthContextHolder7.4.2.HttpUtils7.4.3.Stri…

成员方法传参机制

一、成员方法传参机制 1、值传递&#xff1a;形参改变不影响实参 2、地址传递&#xff1a;形参改变影响实参

函数式编程的技巧

14.1.2 科里化 给出科里化的理论定义之前&#xff0c;让我们先来看一个例子。应用程序通常都会有国际化的需求将一套单位转换到另一套单位是经常碰到的问题。 单位转换通常都会涉及转换因子以及基线调整因子的问题。比如&#xff0c;将摄氏度转换到华氏度的公式是CtoF(x)x*9/…

【高级C语言】从汇编代码看volatile关键字的作用

本人就职于国际知名终端厂商&#xff0c;负责modem芯片研发。 在5G早期负责终端数据业务层、核心网相关的开发工作&#xff0c;目前牵头6G算力网络技术标准研究。 博客内容主要围绕&#xff1a; 5G/6G协议讲解 算力网络讲解&#xff08;云计算&#xff0c;边缘计…

apk反编译修改教程系列---简单去除apk登陆 修改vip与一些反编译基础常识【十二】

往期教程&#xff1a; 安卓玩机-----反编译apk 修改apk 去广告 去弹窗等操作中的一些常识apk反编译修改教程系列-----修改apk应用名称 任意修改名称 签名【一】 apk反编译修改教程系列-----任意修改apk版本号 版本名 防止自动更新【二】 apk反编译修改教程系列-----修改apk中…

政安晨:【示例演绎】【Python】【Numpy数据处理】快速入门(二)

环境准备 大家如果第一次看到&#xff0c;可以先从我这个演绎系列的第一篇文章开始&#xff0c;包括准备环境等等。 第一篇文章如下&#xff1a; 政安晨&#xff1a;【示例演绎】【Python】【Numpy数据处理】快速入门&#xff08;一&#xff09;https://blog.csdn.net/snowd…

怎么搭建自己的网站?

怎么搭建自己的网站 一.领取一个免费域名和SSL证书&#xff0c;和CDN 特点&#xff1a;支持Cloudflare CDN Cloudflare是全球知名的CDN提供商&#xff0c;如果你不想暴露你的源站&#xff0c;又想使用我们的二级域名&#xff0c;不需要前往Cloudflare添加域名&#xff0c;修…

【Linux取经路】文件系统之被打开的文件——文件描述符的引入

文章目录 一、明确基本共识二、C语言文件接口回顾2.1 文件的打开操作2.2 文件的读取写入操作2.3 三个标准输入输出流 三、文件有关的系统调用3.1 open3.1.1 比特位级别的标志位传递方式 3.2 write3.2.1 模拟实现 w 选项3.2.2 模拟实现 a 选项 3.3 read 四、访问文件的本质4.1 再…