【PyQt】13-对话框

news2024/11/22 5:20:05

文章目录

  • 前言
  • 一、知识储备
  • 二、详细展开
    • 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_())

运行结果

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


总结

这篇文章依旧没有总结

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何让Obsidian实现电脑端和安卓端同步

Obsidian是一款知名的笔记软件,支持Markdown语法,它允许用户在多个设备之间同步文件。要在安卓设备上实现同步,可以使用remote save插件,以下是具体操作步骤: 首先是安装电脑端的obsidian,然后依次下载obs…

《Go 简易速速上手小册》第6章:错误处理和测试(2024 最新版)

文章目录 6.1 错误处理机制 - Go 语言中的优雅回旋6.1.1 基础知识讲解6.1.2 重点案例:文件读取器功能描述实现代码 6.1.3 拓展案例 1:网络请求处理器功能描述实现代码 6.1.4 拓展案例 2:数据库查询执行器功能描述实现代码 6.2 编写可测试的代…

GPT SOVITS项目 一分钟克隆 (文字输出)

步骤流程:(首先使用UVR 提取人声文件,然后按下面步骤进行) 注意这里提交的音频是参考的音频

使用EL访问隐式对象

使用EL访问隐式对象 问题陈述 Smart Software Inc.想要开发一款维护雇员数据的Web应用程序。为了实现此目标,该公司决定使用JSP。JSP页面应接受基于雇员姓名、ID、第一语言和第二语言的雇员数据,这些数据由雇员输入。然后,应能在另一个JSP页面上显示这些员工详细信息。另外…

【天衍系列 04】深入理解Flink的ElasticsearchSink组件:实时数据流如何无缝地流向Elasticsearch

文章目录 01 Elasticsearch Sink 基础概念02 Elasticsearch Sink 工作原理03 Elasticsearch Sink 核心组件04 Elasticsearch Sink 配置参数05 Elasticsearch Sink 依赖管理06 Elasticsearch Sink 初阶实战07 Elasticsearch Sink 进阶实战7.1 包结构 & 项目配置项目配置appl…

电商+支付双系统项目------支付系统的构思

本篇文章会讲讲支付的一些相关的名词概念以及怎么去设计支付系统,通过理解支付的这些名词概念和支付系统的架构,为接下来写支付系统的代码做好准备。 目录 支付------支付资质 支付------支付场景 微信 付款码支付 Native支付 支付宝 条码付 扫码…

UE4学习笔记 FPS游戏制作5 动画蒙太奇制作开枪动画

创建一个蒙太奇 选择角色的骨骼,并重命名 编辑蒙太奇 将我们需要的动画拖动到Default下的两个白杠的上边那个里 然后在下方的Sections节点中,点击Preview后的Default,选中后,再点击PreviewAllScetions上百年的长的绿色的Defalut&…

jmeter遇到连接数据库的问题

jmeter连接mysql或者oracle简单,但是连接过inceptor吗? 上货 1、下载驱动inceptor 5.1.2.jar包 2、在添加驱动那里导入 3、在JBC request中的写法 PS:没什么可说的

源聚达科技:抖音店铺2024年卖什么好

随着时代的变迁和科技的进步,消费者的购物习惯与偏好也在不断演变。展望2024年,抖音作为新兴的电商平台,其店铺销售策略需紧跟潮流,才能在激烈的市场竞争中脱颖而出。那么,哪些产品将成为抖音店铺的新宠呢? 首当其冲&…

C#使用迭代器实现文字的动态效果

目录 一、涉及到的知识点 1.GDI 2.Thread类 3.使用IEnumerable()迭代器 二、实例 1.源码 2.生成效果: 一、涉及到的知识点 1.GDI GDI主要用于在窗体上绘制各种图形图像。 GDI的核心是Graphics类,该类表示GDI绘图表面,它提供将对象绘制…

人工智能专题:基础设施行业智能化的基础设施,自智网络双价值分析

今天分享的是人工智能系列深度研究报告:《人工智能专题:基础设施行业智能化的基础设施,自智网络双价值分析》。 (报告出品方:埃森哲) 报告共计:32页 自智网络驱动的电信产业变革 经过多年的…

mysql-E-R图的组成要素及其画法

一、概念结构设计-E-R图方法 实体关系图: 简记E-R图,是指以实体、关系、属性三个基本概念概括数据的基本结构,从而描述静态数据结构的概念模式。 实体型(Entity): 具有相同的特征和性质的集合体,用实体名及其属性名来…

SW2000TSN-千兆百兆车载以太网TSN交换机

更多资讯可以进入官网查看或者联系我们http://www.hdn-vdo.com

智慧公厕的主要应用

在现代社会中,随着城市化进程的加速推进,公共卫生设施的建设和管理变得愈加重要。而智慧公厕作为一种新型城市公共设施,正以其智能化、高效化的特点,成为改善城市卫生环境的重要手段。智慧公厕运用物联网、互联网、大数据、云计算…

SAP PP学习笔记- 豆知识02 - 品目要谁来维护?怎么决定更不更新品目的数量金额?

其实都是在品目类型的Customize中设定的。 咱们这里简单试着说一下什么场景使用。 1,SAP中品目有很多View,都要由哪些部门来维护呢? 其实就是谁用谁维护呗。 在新建一个品目的时候,品目Type本身就决定了该品目要由哪些部门来维…

《Go 简易速速上手小册》第5章:并发编程(2024 最新版)

文章目录 5.1 Goroutines 的基础 - Go 语言中的轻盈舞者5.1.1 基础知识讲解5.1.2 重点案例:并发下载器功能描述实现代码扩展功能 5.1.3 拓展案例 1:网站健康检查功能描述实现代码扩展功能 5.1.4 拓展案例 2:并发日志处理器拓展案例 2&#xf…

异质结太阳能电池中氢化本征非晶硅的设计

在硅异质结太阳能电池(SHJ)中,pn结由两种不同形貌的硅形成,即一种是n型晶体硅(c-Si),另一种是p掺杂(III族)元素掺杂)非晶硅(a-Si)。许…

静态时序分析:SDC约束命令set_clock_transition详解

相关阅读 静态时序分析https://blog.csdn.net/weixin_45791458/category_12567571.html?spm1001.2014.3001.5482 在静态时序分析:SDC约束命令create_clock详解一文的最后,我们谈到了针对理想(ideal)时钟,可以使用set_clock_transition命令直…

java数据结构与算法刷题-----LeetCode696. 计数二进制子串

java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完):https://blog.csdn.net/grd_java/article/details/123063846 文章目录 1. 法一:时间复杂度O(n).空间复杂度O(n)2. 法二&…

【C++ QT项目2】——高仿安信可串口调试助手

【C QT项目2】——高仿安信可串口调试助手 1. 项目概述2. 项目UI设计3. 串口通信核心代码开发3.1 QSerialPort介绍及示例3.2 扫描系统串口3.3 数据的收发3.4 定时发送(QT定时器)3.5 HEX显示与发送 4. 串口调试助手功能的优化4.1 串口的实时扫描4.2 获取系…