目录:
一、对话框综合示例
二、QDialog
三、QInputDialog
四、QMessageDialog
五、QFileDialog
pyqt5的对话框有多种类型,比如输入对话框(QInputDialog)、颜色对话框(QColorDialog)、字体对话框(QFontDialog)、消息对话框(QMessageBox)、文件对话框(QFileDialog)等,他们都是Dialog的子类。
对话框的使用可以提高人机交互,方便用户输入数据,修改参数,改变设置,选择文件等。
一、对话框综合示例
下面,我们通过一个小例子初步了解各类对话框。首先需要说明下,所有的对话框默认为模态窗口,即用户必须处理完当前对话框之后,才可以与父窗口交互。
1 importsys,os2 from PyQt5.QtGui importQIcon3 from PyQt5.QtWidgets import(QWidget,QHBoxLayout,QPushButton,QTextEdit,QFontDialog, QApplication,4 QColorDialog,QInputDialog,QVBoxLayout,QFileDialog,QMessageBox)5
6 path = os.path.dirname(os.path.dirname(os.path.dirname(__file__)))7
8 classMyWindow(QWidget):9 def __init__(self):10 super(MyWindow, self).__init__()11 self.initUI()12
13 definitUI(self):14 self.setWindowTitle('对话框示例')15 self.setWindowIcon(QIcon(r'%s\4.图标素材\chuan.ico' %path))16 self.setGeometry(600,300,500,400)17
18 '''创建三个按键,一个多行文本框'''
19 btn_input = QPushButton('输入')20 btn_font = QPushButton('字体')21 btn_color = QPushButton('颜色')22 btn_file = QPushButton('文件')23 self.text =QTextEdit()24
25 '''将三个按键布置在用一个水平布局容器中,然后将水平布局视为一个整体,与文本框布置在垂直布局中'''
26 hbx =QHBoxLayout()27 hbx.addWidget(btn_input)28 hbx.addWidget(btn_font)29 hbx.addWidget(btn_color)30 hbx.addWidget(btn_file)31
32 vbx =QVBoxLayout()33 vbx.addLayout(hbx)34 vbx.addWidget(self.text)35
36 self.setLayout(vbx)37
38 btn_input.clicked.connect(self.inputDialog)39 btn_font.clicked.connect(self.fontDialog)40 btn_color.clicked.connect(self.colorDialog)41 btn_file.clicked.connect(self.fileDialog)42
43 definputDialog(self):44 text,ok = QInputDialog.getText(self,'输入文本框','请输入您的文本内容')45 #返回值是一个包含两个元素的元组
46 ifok:47 self.text.setText(text)48
49 deffontDialog(self):50 font, ok = QFontDialog.getFont() #返回值是一个包含两个元素的元组
51 ifok:52 self.text.setFont(font)53
54 defcolorDialog(self):55 color =QColorDialog.getColor()56 if color.isValid: #通过isValid()可以判断用户选择的颜色是否有效,若用户选择取消,isValid()将返回false
57 self.text.setTextColor(color)58
59 deffileDialog(self):60 '''打开单个文件'''
61 fname, _ = QFileDialog.getOpenFileName(self, '打开', '/home','Text Files (*.txt)')62 #返回值是包含2个元素的元组,但这里只需要第一个;这里还加了一个过滤器,只打开txt文件
63 iffname:64 f = open(fname, 'r')65 with f:66 data =f.read()67 self.text.setText(data)68
69 defcloseEvent(self, QCloseEvent):70 reply = QMessageBox.question(self,'消息框','您确认退出吗',QMessageBox.Yes|QMessageBox.No,QMessageBox.No)71 ifreply:72 QCloseEvent.accept()73 else:74 QCloseEvent.ignore()75
76
77 if __name__ == '__main__':78 app =QApplication(sys.argv)79 win =MyWindow()80 win.show()81 sys.exit(app.exec_())
对话框示例
效果图如下:
窗体上共有5个控件:4个按键,1个文本框。
def inputDialog(self):
text,ok = QInputDialog.getText(self,'输入文本框','请输入您的文本内容')
if ok:
self.text.setText(text)
(1) “输入”按键连接了inputDialog方法,当用户点击该按键时,会弹出输入文本框。输入文本框可以限制用户输入的内容。例如限制输入字符串,限制用户输入证书,或者限制用户只能从有限内容中选择。当前示例中用户输入的是字符串。其他几种类型后续会详细介绍。当然,用户也可以不通过该输入框直接在文本框内输入内容,这里只是为了做展示,所以“多此一举”。效果如如下:
(2)当用户点击“字体”按键时,可以从字体对话框中选择字体大小,样式和格式。效果图如下:
(3)当用户点击“颜色”对话框时,会弹出颜色对话框,该对话框有以下几种功能:
从基础颜色中选择需要的颜色;
从色谱图中选择所需颜色;
将喜欢的颜色添加到常用颜色中;
使用取色器在屏幕上取色;
微调三原色数值。
效果图及对应功能如下:
(4)当用户点击“文件”按键时,会弹出文件对话框。这里可以设置文件对话框弹出式父组件、标题、默认打开目录以及文件扩展名过滤器,后面会详细介绍。在当前示例中,只能打开单个文件,且只允许用户打开txt文件,并将文件内容写到文本框中。效果图如下:
(5)当用户退出主窗口时,会弹出消息框,不再详述,效果图如下:
二、QDialog
所有对话框窗体的标题栏上没有最小化和最大化控件,且默认为模态窗口。如果需要修改该属性,可调用setWindowModality()方法,取值如下:
Qt.NonModal。非模态,在未关闭对话框时,可以和程序的其他窗口进行交互;
Qt.WindowModal。模态窗口。用户必须处理完当前对话框,才可以和父窗口交互;
Qt.ApplicationModal。应用程序级模态,即用户在未处理完当前对话框时,不能和任何其他窗口进行交互。
用法如下
Dialog.setWindowModality(Qt.WindowModal)
三、QInputDialog
QInputDialog 控件是一个标准对话框,由一个输入文本框和两个按钮组成。可以从该对话框中获得字符串、数字和列表选项。常用方法如下:
getItem()。限制选择列表中已有选项
getDouble()。限制浮点数输入
getInt()。限制整数输入
getText()。获得字符串
1 importsys,os2 from PyQt5.QtWidgets importQWidget,QApplication,QInputDialog,QPushButton,QLineEdit,QHBoxLayout,QVBoxLayout3 from PyQt5.QtGui importQIcon4
5 path = os.path.dirname(os.path.dirname(os.path.dirname(__file__)))6
7 classMyWindow(QWidget):8 def __init__(self):9 super(MyWindow, self).__init__()10 self.initUI()11
12 definitUI(self):13 self.setWindowTitle('QInputDialog示例')14 self.setWindowIcon(QIcon(r'%s\4.图标素材\chuan.ico' %path))15 self.setGeometry(600,300,350,200)16
17 btn_str = QPushButton('获得字符串')18 btn_int = QPushButton('获得整数')19 btn_item = QPushButton('获得列表选项')20 self.lineEdit_str =QLineEdit()21 self.lineEdit_int =QLineEdit()22 self.lineEdit_item =QLineEdit()23
24 vbx1 =QVBoxLayout()25 vbx1.addWidget(btn_int)26 vbx1.addWidget(btn_item)27 vbx1.addWidget(btn_str)28
29 vbx2 =QVBoxLayout()30 vbx2.addWidget(self.lineEdit_int)31 vbx2.addWidget(self.lineEdit_item)32 vbx2.addWidget(self.lineEdit_str)33
34 hbx =QHBoxLayout()35 hbx.addLayout(vbx1)36 hbx.addLayout(vbx2)37 self.setLayout(hbx)38
39 btn_item.clicked.connect(self.getItem)40 btn_int.clicked.connect(self.getInt)41 btn_str.clicked.connect(self.getStr)42
43 defgetItem(self):44 items = ['装载机','平地机','推土机','挖掘机','自卸车'] #这里设置成列表或元组都可以
45 item, ok = QInputDialog.getItem(self,'选择项目','请选择您的需求',items,0,False)46 if ok anditem:47 self.lineEdit_item.setText(item)48
49 defgetInt(self):50 #num,ok = QInputDialog.getDouble(self,'双精度','输入您得数字')
51 num, ok = QInputDialog.getInt(self,'获取整数','输入您的数字(-10~10)',0,-10,10,1)52 ifok:53 self.lineEdit_int.setText(str(num))54
55 defgetStr(self):56 str, ok = QInputDialog.getText(self,'获取字符串','请输入您的文本',QLineEdit.Normal,'字符串',)57 ifok:58 self.lineEdit_str.setText(str)59
60
61 if __name__ == '__main__':62 app =QApplication(sys.argv)63 win =MyWindow()64 win.show()65 sys.exit(app.exec_())
QInputDialog示例
效果图如下:
3.1 getItem()
defgetItem(self):
items= ['装载机','平地机','推土机','挖掘机','自卸车']
item, ok= QInputDialog.getItem(self,'选择项目','请选择您的需求',items,0,False)if ok anditem:
self.lineEdit_item.setText(item)
该方法限制用户只能在给定的有限内容中做选择。“有限的内容”即示例中的items,这里设置成列表或者元组都是可以的。其次,geiItem方法参数较多,下面进行讲解:
QInputDialog.getItem(QWidget, str, str, list-of-str, int current=0, bool editable=True)
参数依次为:父组件;对话框标题;对话框提示信息;列表对象;默认显示值在列表中的索引值;控件中显示的文字是否可编辑(True:可编辑;False:不可编辑)
3.2 getInt()和getDouble()
defgetInt(self):#num,ok = QInputDialog.getDouble(self,'双精度','输入您得数字')
num, ok = QInputDialog.getInt(self,'获取整数','输入您的数字(-10~10)',0,-10,10,1)ifok:
self.lineEdit_int.setText(str(num))
getInt()和getDouble()使用方法是完全相同的。注意最后将输入值传给父组件时一定要把数据变为字符串。同样的,该方法参数众多,下面进行介绍:
QInputDialog.getInt(QWidget, str, str, int value=0, int min=-2147483647, int max=2147483647, int step=1)
第一个参数为父组件;
第二个参数为对话框标题;
第三个参数为对话框提示信息;
第四个参数为默认值;
第五个参数为允许输入的最小值;
第六个参数为允许输入的最大值;
第七个参数为步长
3.3 getText()
defgetStr(self):
str, ok= QInputDialog.getText(self,'获取字符串','请输入您的文本',QLineEdit.Normal,'字符串',)ifok:
self.lineEdit_str.setText(str)
QInputDialog.getText(QWidget, str, str, QLineEdit.EchoMode echo=QLineEdit.Normal, str text=QString())
几个参数依次是:父组件;对话框标题;对话框提示信息;对话框中QLineEdit控件的输入模式;默认值。其中,对话框中QLineEdit控件的输入模式有4种,详情如下表:
常量
值
内容
QLineEdit.Normal
正常显示输入的字符,默认选项。
QLineEdit.NoEcho
1
不显示任何输入,常用于密码类型,其密码长度都需要保密的时候。
QLineEdit.Password
2
显示平台相关的密码掩码字符,而不是实际的字符输入。
QLineEdit.PasswordEchoOnEdit
3
在编辑的时候显示字符,负责显示密码类型。
四、QMessageDialog
1 importsys,os2 from PyQt5.QtWidgets importQWidget,QApplication,QMessageBox,QPushButton,QHBoxLayout,QVBoxLayout3 from PyQt5.QtGui importQIcon4
5 path = os.path.dirname(os.path.dirname(os.path.dirname(__file__)))6
7 classMyWindow(QWidget):8
9 def __init__(self):10 super(MyWindow, self).__init__()11 self.initUI()12
13 definitUI(self):14 self.setWindowTitle('QMessageDialog示例')15 self.setWindowIcon(QIcon(r'%s\4.图标素材\chuan.ico' %path))16 self.setGeometry(600,300,350,200)17
18 self.btn_question = QPushButton('问答对话框')19 self.btn_warning = QPushButton('警告对话框')20 self.btn_critical = QPushButton('严重错误对话框')21 self.btn_about = QPushButton('关于对话框')22
23 vbx =QVBoxLayout()24 vbx.addWidget(self.btn_about)25 vbx.addWidget(self.btn_critical)26 vbx.addWidget(self.btn_question)27 vbx.addWidget(self.btn_warning)28
29 hbx =QHBoxLayout()30 hbx.addStretch(1)31 hbx.addLayout(vbx)32 hbx.addStretch(1)33 self.setLayout(hbx)34
35 self.btn_question.clicked.connect(self.showquestion)36 self.btn_warning.clicked.connect(self.showwarning)37 self.btn_critical.clicked.connect(self.showcritical)38 self.btn_about.clicked.connect(self.showabout)39
40
41 defshowquestion(self):42 QMessageBox.question(self,'问答对话框','这是一个问答对话框',QMessageBox.Yes|QMessageBox.No,QMessageBox.Yes)43
44 defshowwarning(self):45 QMessageBox.warning(self, '警告对话框', '这是一个警告对话框', QMessageBox.Yes |QMessageBox.No, QMessageBox.Yes)46
47 defshowcritical(self):48 QMessageBox.critical(self, '严重错误对话框', '这是一个严重错误对话框', QMessageBox.Yes |QMessageBox.No, QMessageBox.Yes)49
50 defshowabout(self):51 QMessageBox.about(self, '关于对话框', '这是一个关于对话框')52
53
54 if __name__ == '__main__':55 app =QApplication(sys.argv)56 win =MyWindow()57 win.show()58 sys.exit(app.exec_())
QMessageDialog示例
效果图如下:
该窗体上共有四个按键,对应四种类型的消息对话框。
其中,问答对话框,警告对话框,严重错误对话框的方法相同,以问答对话框为例,QMessageDialog.question(父组件,’对话框标题‘,’对话框内容‘,按键一|按键二,默认按键)。关于对话框只有一个按键ok,不需要用户指定按键,所以只需要给定前三项参数即可。在示例中,我们使用了Yes和No两个按键,实际上pyqt中案件类型不止这两种。
类型
作用
QMessage.Yes
是
QMessage.No
否
QMessage.Ok
确认
QMessage.Cancel
取消
QMessage.About
关于
QMessage.Retry
重试
QMessage.Ignore
忽略
五、QFileDialog
QFileDialog是用于打开和保存文件的对话框,常用的方法如下:
方法
内容
getOpenFileName()
返回所选文件的名称,并打开该文件(单个文件)
getOpenFileNames()
返回所选文件的名称,并打开该文件(多个文件)
getSaveFileName()
以用户选择的名称给文件命名
setFileMode()
可以选择文件类型,枚举常量是:
QFileDialog.AnyFile 任何文件
QFileDialog.ExistingFile 已存在的文件
QFileDialog.Directory 文件目录
QFileDialog.ExistingFiles 因存在的多个文件
setFilter
设置过滤器,只显示过滤器允许的文件类型
综合示例中getOpenFileName()方法的各参数释义如下:
getOpenFileName(父组件,标题,对话框打开时默认显示的目录,扩展名过滤器)。当扩展名过滤器需要显示多种文件类型时,各类型之间需要用两个分号隔开。示例如下
1 importsys,os2 from PyQt5.QtWidgets importQWidget,QApplication,QFileDialog,QPushButton,QTextEdit,QVBoxLayout3 from PyQt5.QtGui importQIcon4
5 path = os.path.dirname(os.path.dirname(os.path.dirname(__file__)))6
7 classMyWindow(QWidget):8 def __init__(self):9 super(MyWindow, self).__init__()10 self.initUI()11
12 definitUI(self):13 self.setWindowTitle('QFileDialog示例')14 self.setWindowIcon(QIcon(r'%s\4.图标素材\chuan.ico' %path))15 self.setGeometry(600,300,350,200)16
17 btn = QPushButton('打开文件')18 self.text =QTextEdit()19
20 vbx =QVBoxLayout()21 vbx.addWidget(btn)22 vbx.addWidget(self.text)23 self.setLayout(vbx)24
25 btn.clicked.connect(self.openfile)26
27 defopenfile(self):28 fname, _ = QFileDialog.getOpenFileName(self,'打开文件','C:\\','TXT Files(*.txt);;DOC Files(*.docx)')29 iffname:30 f = open(fname, 'r')31 with f:32 data =f.read()33 self.text.setText(data)34
35
36 if __name__ == '__main__':37 app =QApplication(sys.argv)38 win =MyWindow()39 win.show()40 sys.exit(app.exec_())
QFileDialog示例
效果图如下: