基于PyQt4和PySide实现输入对话框效果


Posted in Python onFebruary 27, 2019

今天做了个基于PyQt4和PySide的输入对话框.已放到PyPi中,包名wlab,大家可以使用pip安装:

pip install wlab

在程序输入中,有时会要求同时改变多个参数值,而且类型也不尽相同,
这时下面的模块比较彻底的解决了这个问题.先看个示例吧.

比如我们有三个参数,分别为int,float,和字符串类型:

values={'String':'This is String','float':3.5,'int':15}
GroupBoxTitle='Please set values:'
title='QInputBox:'
rvalues=QInputBox(values=values,GroupBoxTitle=GroupBoxTitle,title=title)
print(rvalues)

生成的GUI界面如下:

基于PyQt4和PySide实现输入对话框效果

返回的结果中我们注意到字典rvalues里面数据的类型和字典valuse中时一致的.

也就是说:

如果values中是整数,那么rvalue中的值也是整数;

如果value中是浮点数,那么rvalue中的值也是浮点数;

如果value中是字符串,那么rvalue中的值也是字符串;

目前只支持这三种类型.但对values中输入参数并没有没有数目限制.

对于不会使用pip的新手,可以复制下面的文件:

#-*- coding:utf-8 -*-
#~ #--------------------------------------------------------------------------------
#~ module:wlab
#~ FileName=WPyQtInput.py
#~Class:QInputGroupBox,QInputDialog,QInputBox
#~ author:Wu Xuping
#~ Date:2013-05-06
#~ Email:539688300@qq.com
#~ Remark:based on PyQt4 or PySide
#~ #-------------------------------------------------
 
try:
  from PyQt4 import QtGui
  from PyQt4 import QtCore
  from PyQt4.QtCore import pyqtSlot
  from PyQt4.QtCore import pyqtSignal
  IsPyQt=True
  IsPySide=False
except ImportError:
  from PySide import QtGui
  from PySide import QtCore
  from PySide.QtCore import Slot as pyqtSlot
  from PySide.QtCore import Signal as pyqtSignal
  IsPyQt=False
  IsPySide=True
#~ #-------------------------------------------------
 
#~ #-------------------------------------------------
#~ #将字符串一特定的长度输出
def FormatStr(MaxStrLength,s):
  if (len(s)<MaxStrLength):
    for n in range(MaxStrLength-len(s)):
      s=' '+s
 
  rs=str(s)+':'
  return rs
 
class IntLineEdit(QtGui.QLineEdit):
  def __init__ (self,num=0):
    '''
    #~ IntLineEdit(num)
    '''
    QtGui.QLineEdit.__init__ (self)
    self.num=num
    self.setText(str(self.num))
 
  @pyqtSlot(int)
  def setValue(self,n):
    self.setText(str(n))
    return (self.num,n)
 
class FloatLineEdit(QtGui.QLineEdit):
  def __init__ (self,num=0.0):
    '''
    #~ FloatLineEdit(num)
    '''
    QtGui.QLineEdit.__init__ (self)
    self.num=num
    self.setText(str(self.num))
 
  @pyqtSlot(int)
  def setValue(self,n):
    if ( self.num>0):
      self.setText(str(self.num+n*self.num/50.0))
    else:
      self.setText(str(self.num-n*self.num/50.0))
    return (self.num,n)
#~ #-------------------------------------------------
class QInputGroupBox(QtGui.QGroupBox):
  def __init__(self, values={'String':'This is String','float':3.5,'int':15},title='Please set values',ntimes=2.0,parent=None):
    '''
    #~#---------------------------------------------------
    #~#Examples:
    #~#---------------------------------------------------
    #~ >>>values={'String':'This is String','float':3.5,'int':15}
    #~ >>>GroupBoxTitle='Please set values'
    #~ >>>self.QIGBox=QInputGroupBox(values=values,title=GroupBoxTitle,ntimes=2.0,parent=self)
    #~ >>>rvalues=self.QIGBox.GetOriginValue()
    #~ >>>rvalues=self.QIGBox.GetModifiedValues()
    #~#---------------------------------------------------
    #~#Parameters:
    #~#---------------------------------------------------
    #~#values={'String':'This is String','float':3.5,'int':15}
    #~#title='Please set values'
    #~#ntimes=2.0
    #~#parent=None
    '''
    QtGui.QGroupBox.__init__ (self, title=title,parent = parent)
 
    self.OriginValues=values.copy()
    self.ModifiedValues=values.copy()
 
    MaxStrLength=max([len(str(s)) for s in list(values.keys())])
 
    layout = QtGui.QGridLayout()
    cnt=0
    for key in self.ModifiedValues:
      label=FormatStr(MaxStrLength,str(key))
      KeyLabel=QtGui.QLabel(label)
      layout.addWidget(KeyLabel, cnt, 0)
      ovk=self.ModifiedValues[key]
 
      if(type(ovk)==int) :
        valueLineEdit=IntLineEdit(ovk)
        layout.addWidget(valueLineEdit, cnt , 1)
        slider=QtGui.QSlider(orientation= QtCore.Qt.Horizontal)
        if (ovk>0):
          slider.setRange( ovk/(ntimes+1), ovk*(ntimes+1))
        elif (ovk==0):
          slider.setRange( -5*(ntimes+1), 5*(ntimes+1))
        else:
          slider.setRange(ovk*(ntimes+1),ovk/(ntimes+1))
        slider.setValue(ovk)
        QtCore.QObject.connect(slider,QtCore.SIGNAL('valueChanged(int)'),
              valueLineEdit, QtCore.SLOT('setValue(int)'))
        layout.addWidget(slider, cnt ,2)
 
      elif(type(ovk)==float) :
        valueLineEdit=FloatLineEdit(ovk)
 
        layout.addWidget(valueLineEdit, cnt , 1)
        slider=QtGui.QSlider(orientation= QtCore.Qt.Horizontal)
        slider.setRange( -50*ntimes, 50*ntimes)
        QtCore.QObject.connect(slider,QtCore.SIGNAL('valueChanged(int)'),
              valueLineEdit, QtCore.SLOT('setValue(int)'))
        layout.addWidget(slider, cnt ,2)
 
      else:
        valueLineEdit=QtGui.QLineEdit(ovk)
        layout.addWidget(valueLineEdit, cnt, 1,1,2)
 
      #~ #set an object name for QLineEdit,Later we can use findchild() to find it
      valueLineEdit.setObjectName('VLE'+str(cnt))
 
      layout.setRowStretch(cnt,5)
      cnt=cnt+1
 
    layout.setColumnStretch(0, 1)
    layout.setColumnStretch(1, 5)
    layout.setColumnStretch(2, 10)
 
    self.setLayout(layout)
 
 
  def GetOriginValue(self):
    '''
    #~ if the user click btn_Cancel,then return OriginValues
    '''
    return self.OriginValues
 
  def GetModifiedValues(self):
    '''
    #~ if the user click btn_OK,then return self.ModifiedValues
    '''
    cnt=0
    for key in self.ModifiedValues:
      keyStr=str(key)
      VLEObjectName='VLE'+str(cnt)
      if (IsPyQt):
        VLE=self.findChild((QtGui.QLineEdit, ),VLEObjectName)
      else:
        VLE=self.findChild(QtGui.QLineEdit,VLEObjectName)
      cnt=cnt+1
      ovk=self.ModifiedValues[key]
      if(type(ovk)==int):
        self.ModifiedValues[key]=int(VLE.text())
      elif(type(ovk)==float):
        self.ModifiedValues[key]=float(VLE.text())
      else:
        self.ModifiedValues[key]=str(VLE.text())
 
    return self.ModifiedValues
#~ #-------------------------------------------------
class QInputDialog(QtGui.QDialog):
  def __init__(self, values={'String':'This is String','float':3.5,'int':15},GroupBoxTitle='Please set values',title='QInputDialog:',parent=None):
    '''
    #~ >>>values={'String':'This is String','float':3.5,'int':15}
    #~ >>>GroupBoxTitle='Please set values'
    #~ >>>title='QInputDialog:'
    #~ >>>dlg = QInputDialog(values=values,GroupBoxTitle=GroupBoxTitle,title=title,parent=None)
    #~ >>>if ( dlg.exec_() == QtGui.QDialog.Accepted):
     #~ >>>   rvalues = dlg.GetModifiedValues()
    #~ >>>else:
    #~ >>>   rvalues = dlg.GetOriginValue()
    '''
    QtGui.QDialog.__init__(self, parent=parent)
    self.setWindowTitle(title)
    self.QIGBox=QInputGroupBox(values=values,title=GroupBoxTitle,parent=self)
 
    self.vbox = QtGui.QVBoxLayout()
    self.vbox.addWidget(self.QIGBox)
 
    self.btn_OK=QtGui.QDialogButtonBox(QtGui.QDialogButtonBox.Ok)
    self.btn_Cancel=QtGui.QDialogButtonBox(QtGui.QDialogButtonBox.Cancel)
 
    self.btn_OK.clicked.connect(self.accept )
    self.btn_Cancel.clicked.connect(self.reject)
 
    hbox = QtGui.QHBoxLayout()
    hbox.addWidget(self.btn_OK)
    hbox.addWidget(self.btn_Cancel)
    self.vbox.addLayout(hbox)
    self.setLayout(self.vbox)
 
  def GetOriginValue(self):
    '''
    #~ if the user click btn_Cancel,then return OriginValues
    '''
    return self.QIGBox.GetOriginValue()
 
  def GetModifiedValues(self):
    '''
    #~ if the user click btn_OK,then return self.ModifiedValues
    '''
    return self.QIGBox.GetModifiedValues()
#~ #-------------------------------------------------
#~ #Good packaging QInputBox
def QInputBox(values={'String':'This is String','float':3.5,'int':15},GroupBoxTitle='Please set values',title='QInputBox'):
  '''
  #~ >>>values={'String':'This is String','float':3.5,'int':15}
  #~ >>>GroupBoxTitle='Please set values'
  #~ >>>title='QInputBox'
  #~ >>>rvalues=QInputBox(values=values,GroupBoxTitle=GroupBoxTitle,title=title)
  #~ >>>print(rvalues)
  #~ #>>>rvalues=QInputBox(values,GroupBoxTitle)
  #~ #>>>rvalues=QInputBox(values)
  #~ #>>>rvalues=QInputBox()
  '''
  #app = QtGui.QApplication(sys.argv)#已自动创建,无需再创建
  dlg = QInputDialog(values=values,GroupBoxTitle=GroupBoxTitle,title=title)
  if ( dlg.exec_() == QtGui.QDialog.Accepted):
    rvalues = dlg.GetModifiedValues()
  else:
    rvalues = dlg.GetOriginValue()
  return rvalues
 
#~ #---------------------------------------------------------------------------------------------------------
#~ # main test program for __WPyQtInput__.py
#~ #---------------------------------------------------------------------------------------------------------
if __name__ == '__main__':
  #----------------------------------------------------------------------------------------
  try:
    from PyQt4 import QtGui
    from PyQt4 import QtCore
    from PyQt4.QtCore import pyqtSlot
    from PyQt4.QtCore import pyqtSignal
    IsPyQt=True
    IsPySide=False
  except ImportError:
    from PySide import QtGui
    from PySide import QtCore
    from PySide.QtCore import Slot as pyqtSlot
    from PySide.QtCore import Signal as pyqtSignal
  #----------------------------------------------------------------------------------------
  import sys
  app = QtGui.QApplication(sys.argv)#创建Qt进程app
  #----------------------------------------------------------------------------------------
  #示例1
  values={'String':'This is String','float':-3.5,'int':-15}
  GroupBoxTitle='Please set values'
  title='the first example of QInputBox '
  rvalues=QInputBox(values=values,GroupBoxTitle=GroupBoxTitle,title=title)
  print(rvalues)
  #>>>{'int': -15, 'float': -3.5, 'String': 'This is String'}
  #----------------------------------------------------------------------------------------
  #示例2
  from collections import OrderedDict
  values=OrderedDict([('c', 1), (2, 2), ('a', 3)])
  rvalues1=QInputBox(values=values)
  print(rvalues1)
  #>>>OrderedDict([('c', 1), (2, 2), ('a', 3)])
  #----------------------------------------------------------------------------------------
  #示例3
  values={'String':'This is String','float':-3.5,'int':-15}
  GroupBoxTitle='Please set values'
  title='QInputBox'
  rvalues2=QInputBox(values=values,GroupBoxTitle=GroupBoxTitle,title=title)
  print(rvalues2)
  #>>>{'int': -15, 'float': -3.5, 'String': 'This is String'}
  #----------------------------------------------------------------------------------------
  sys.exit(app.exec_())

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python中使用urllib2防止302跳转的代码例子
Jul 07 Python
Python 功能和特点(新手必学)
Dec 30 Python
python中验证码连通域分割的方法详解
Jun 04 Python
Django添加sitemap的方法示例
Aug 06 Python
Python-while 计算100以内奇数和的方法
Jun 11 Python
python设置随机种子实例讲解
Sep 12 Python
在pycharm中实现删除bookmark
Feb 14 Python
pytorch实现Tensor变量之间的转换
Feb 17 Python
Python函数参数定义及传递方式解析
Jun 10 Python
详解pyqt5的UI中嵌入matplotlib图形并实时刷新(挖坑和填坑)
Aug 07 Python
Python 解析库json及jsonpath pickle的实现
Aug 17 Python
Python jieba结巴分词原理及用法解析
Nov 05 Python
python使用PyQt5的简单方法
Feb 27 #Python
Python创建字典的八种方式
Feb 27 #Python
基于wxPython的GUI实现输入对话框(2)
Feb 27 #Python
基于wxPython的GUI实现输入对话框(1)
Feb 27 #Python
Python使用字典的嵌套功能详解
Feb 27 #Python
Python list列表中删除多个重复元素操作示例
Feb 27 #Python
WxPython建立批量录入框窗口
Feb 27 #Python
You might like
PHP5下$_SERVER变量不再受magic_quotes_gpc保护的弥补方法
2012/10/31 PHP
Discuz批量替换帖子内容的方法(使用SQL更新数据库)
2014/06/23 PHP
PHP从二维数组得到N层分类树的实现代码
2016/10/11 PHP
使用jQuery插件创建常规模态窗口登陆效果
2013/08/23 Javascript
jQuery实现表格展开与折叠的方法
2015/05/04 Javascript
深入解析JavaScript中的数字对象与字符串对象
2015/10/21 Javascript
Jquery1.9.1源码分析系列(十五)动画处理之外篇
2015/12/04 Javascript
JavaScript字符串删除重复字符的方法
2015/12/25 Javascript
AngularJS基础 ng-init 指令简单示例
2016/08/02 Javascript
详解Vue.js之视图和数据的双向绑定(v-model)
2017/06/23 Javascript
js实现控制文件拖拽并获取拖拽内容功能
2018/02/17 Javascript
JS实现查找数组中对象的属性值是否存在示例
2019/05/24 Javascript
基于layui table返回的值的多级嵌套的解决方法
2019/09/19 Javascript
使用Karma做vue组件单元测试的实现
2020/01/16 Javascript
vue中的使用token的方法示例
2020/03/10 Javascript
[40:06]DOTA2亚洲邀请赛 4.3 突围赛 Liquid vs VGJ.T 第一场
2018/04/04 DOTA
Python实现一个服务器监听多个客户端请求
2018/04/12 Python
Python3.x爬虫下载网页图片的实例讲解
2018/05/22 Python
keras打印loss对权重的导数方式
2020/06/10 Python
Python同时处理多个异常的方法
2020/07/28 Python
Python命名空间及作用域原理实例解析
2020/08/12 Python
python之语音识别speech模块
2020/09/09 Python
HTML5里的placeholder属性使用实例和美化显示效果的方法
2014/04/23 HTML / CSS
澳大利亚家居用品零售商:Harris Scarfe
2020/10/10 全球购物
J2EE的优越性主要表现在哪些方面
2016/03/28 面试题
网络维护管理员的自我评价分享
2013/11/11 职场文书
初中生个人学习的自我评价
2013/12/04 职场文书
致铅球运动员加油稿
2014/02/13 职场文书
艺术设计专业求职自荐信
2014/05/19 职场文书
怎样写离婚协议书
2014/09/10 职场文书
公司离职证明标准样本
2014/10/05 职场文书
秦始皇兵马俑导游词
2015/02/02 职场文书
2015最新学生自我评价范文
2015/03/03 职场文书
实习介绍信范文
2015/05/05 职场文书
python实现三阶魔方还原的示例代码
2021/04/28 Python
MYSQL如何查看进程和kill进程
2022/03/13 MySQL