基于wxPython的GUI實(shí)現(xiàn)輸入對(duì)話框(2)
接著上一篇基于wxPython的GUI輸入對(duì)話框1,繼續(xù)學(xué)習(xí)。
在程序輸入中,有時(shí)會(huì)要求同時(shí)改變多個(gè)參數(shù)值,而且類型也不盡相同,
這時(shí)TextEntryDialog就顯得不適用了.WxInput模塊則比較徹底的解決了這個(gè)問(wèn)題.
比如我有三個(gè)值要用戶交互式設(shè)置,一個(gè)是int數(shù),一個(gè)是str,一個(gè)是float,先看示例文件:
from WInput import InputBox values={'int':1,'String':'This is String','float':3.5} title='Setting values:' rvalues=InputBox(title,values) print(rvalues)
顯示GUI如下:
上面的代碼的關(guān)鍵是設(shè)置字典values的值.
WxInput會(huì)自動(dòng)根據(jù)字典values的內(nèi)容生成輸入界面,
而且返回值的類型確保和原始類型一樣.
再比如程序中有任意兩個(gè)參數(shù)Method和num要設(shè)置,那么如下就可了:
title='Setting values:' values={'Method':'LogLog','Value':3.5} rvalues=InputBox(title,values)
生成的界面如下:
WxInput模塊的代碼如下:
#-*- coding:utf-8 -*- #~ #-------------------------------------------------------------------------------- #~ module:wlab #~ FileName=WInput.py #~ Funciton:wx的輸入對(duì)話框 #~ author:吳徐平 #~ Date:2013-04-28 #~ Email:539688300@qq.com #~ #------------------------------------------------- import wx import wx.lib.sized_controls as wxsc #~ #------------------------------------------------- #~ #set value for widgets( StaticText and TextCtrl) height wh=30 #~ #set value for max width times mwt=8 #~ #set value for wh times wht=3 #~ #------------------------------------------------- class InputDialog(wxsc.SizedDialog): def __init__(self,title='Setting values:',values={'int':1,'String':'This is String','float':3.5}): ''' #~ using it as follow: #~ dialog = InputDialog(title='Setting values:',values={'int':1,'String':'This is String','float':3.5}) #~ just for test: #~ dialog = InputDialog() ''' style = wx.DEFAULT_DIALOG_STYLE | wx.RESIZE_BORDER wxsc.SizedDialog.__init__(self,parent=None, id=-1, title=title, style=style) self.originvalues=values.copy() self.modifiedvalues=values.copy() self.pane = self.GetContentsPane() self.pane.SetSizerType("form") maxlen1=mwt*max([len(str(key)) for key in values]) if maxlen1<wh*wht: maxlen1=wh*wht maxlen2=mwt*max([len(str(values[key])) for key in values]) if maxlen2<wh*wht: maxlen2=wh*wht for key in self.modifiedvalues: keyStr=str(key) label=keyStr+' :' StaticText = wx.StaticText(parent=self.pane,id=-1,label=label,style=wx.ALIGN_RIGHT) StaticText.SetInitialSize((maxlen1,wh)) value=str(self.modifiedvalues[key]) TextCtrl = wx.TextCtrl(parent=self.pane, id=-1,value=value) TextCtrl.SetInitialSize((maxlen2,wh)) TextCtrl.SetSizerProps(expand=True) #~set a name for TextCtrl,so later we can use wx.FindWindowByName() TextCtrl.Name='TC_'+str(keyStr) #StaticText.Name='ST_'+str(keyStr) #~ # add dialog buttons self.SetButtonSizer(self.CreateStdDialogButtonSizer(wx.OK | wx.CANCEL)) self.Fit() self.Center() def GetOriginValue(self): ''' #~ if the user select wx.ID_CANCEL,then return originvalues ''' return self.originvalues def GetValue(self): ''' #~ if the user select wx.ID_OK,then return self.modifiedvalues ''' for key in self.modifiedvalues: keyStr=str(key) TextCtrlName='TC_'+str(keyStr) TextCtrl=self.FindWindowByName(TextCtrlName) ovk=self.modifiedvalues[key] if(type(ovk)==int): self.modifiedvalues[key]=int(TextCtrl.GetValue().strip()) elif(type(ovk)==float): self.modifiedvalues[key]=float(TextCtrl.GetValue().strip()) else: self.modifiedvalues[key]=str(TextCtrl.GetValue()) return self.modifiedvalues #~ #------------------------------------------------- def InputBox(title='Setting values',values={'int':1,'String':'This is String','float':3.5}): ''' #~ >>>values={'int':1,'String':'This is String','float':3.5} #~ >>>title='Setting values:' #~ >>>rvalues=InputBox(title,values) #~ >>>print(rvalues): ''' app = wx.PySimpleApp() dialog = InputDialog(title=title,values=values) if dialog.ShowModal() == wx.ID_OK: values= dialog.GetValue() else: values=dialog.GetOriginValue() dialog.Destroy() app.MainLoop() return values ##~ #測(cè)試InputBox #if __name__ == '__main__': #values={'int':1,'String':'This is String','float':3.5} #title='Setting values' #rvalues=InputBox(title,values=values) #print(rvalues) ##~ #------------------------------------------------- class InputPanel(wx.Panel): def __init__(self,parent,label='Setting values:',values={'int':1,'String':'This is String','float':3.5}): ''' #~ >>>ipl = InputPanel(parent,label='Setting values:',values={'int':1,'String':'This is String','float':3.5}) #~>>> rvalues=ipl.GetValue(self) ''' wx.Panel.__init__(self,parent=parent, id=-1) self.modifiedvalues=values.copy() box = wx.StaticBox(self, -1, label=label) sbsizer = wx.StaticBoxSizer(box, wx.VERTICAL) gridsizer = wx.FlexGridSizer(cols=2, hgap=5, vgap=5) maxlen1=mwt*max([len(str(key)) for key in values]) if maxlen1<wh*wht: maxlen1=wh*3 maxlen2=mwt*max([len(str(values[key])) for key in values]) if maxlen2<wh*wht: maxlen2=wh*wht for key in self.modifiedvalues: keyStr=str(key) label=keyStr+' :' StaticText = wx.StaticText(parent=self,id=-1,label=label,style=wx.ALIGN_RIGHT) StaticText.SetInitialSize((maxlen1,wh)) gridsizer.Add(StaticText, 0, wx.EXPAND|wx.ALIGN_CENTER_VERTICAL|wx.LEFT|wx.RIGHT, 3) value=str(self.modifiedvalues[key]) TextCtrl = wx.TextCtrl(parent=self, id=-1,value=value) TextCtrl.SetInitialSize((maxlen2,wh)) gridsizer.Add(TextCtrl, 0, wx.EXPAND|wx.ALIGN_CENTER_VERTICAL|wx.LEFT|wx.RIGHT, 3) #~set a name for TextCtrl,so later we can use wx.FindWindowByName() TextCtrl.Name='TC_'+str(keyStr) sbsizer.Add(gridsizer, 1, wx.EXPAND) gridsizer.Layout() PanelSizer = wx.BoxSizer(wx.VERTICAL) PanelSizer.Add(sbsizer, 0, wx.ALL|wx.EXPAND, 5) self.SetSizer(PanelSizer) PanelSizer.Layout() PanelSizer.Fit(self) def GetValue(self): ''' #~ return self.modifiedvalues ''' for key in self.modifiedvalues: keyStr=str(key) TextCtrlName='TC_'+str(keyStr) TextCtrl=self.FindWindowByName(TextCtrlName) ovk=self.modifiedvalues[key] if(type(ovk)==int): self.modifiedvalues[key]=int(TextCtrl.GetValue().strip()) elif(type(ovk)==float): self.modifiedvalues[key]=float(TextCtrl.GetValue().strip()) else: self.modifiedvalues[key]=str(TextCtrl.GetValue()) return self.modifiedvalues ##~ #------------------------------------------------- class InputFrame(wx.Frame): def __init__(self,title='InputFrame:',label='Setting values:',values={'int':1,'String':'This is String','float':3.5},size=(400,200)): ''' #~ >>>IFrame = InputFrame(title='InputFrame:',label='Setting values:',values={'int':1,'String':'This is String','float':3.5},size=(400,200)): #~>>> rvalues=IFrame.GetValue() ''' wx.Frame.__init__(self,parent=None,title = title,size=size) self.modifiedvalues=values.copy() self.IPL = InputPanel(self,label=label,values=values) #~ #創(chuàng)建FlexGridSizer self.FlexGridSizer=wx.FlexGridSizer( rows=9, cols=1, vgap=5,hgap=5) self.FlexGridSizer.SetFlexibleDirection(wx.BOTH) self.RightPanel = wx.Panel(self,-1) #~ #測(cè)試按鈕1 self.Button1 = wx.Button(self.RightPanel,-1,"TestButton",size=(100,40),pos=(10,10)) self.Button1.Bind(wx.EVT_BUTTON,self.GetValue) #~ #加入Sizer中 self.FlexGridSizer.Add(self.Button1,proportion =0, border = 5,flag = wx.ALL | wx.EXPAND) self.RightPanel.SetSizer(self.FlexGridSizer) self.BoxSizer=wx.BoxSizer(wx.HORIZONTAL) self.BoxSizer.Add(self.IPL,proportion =-10, border = 2,flag = wx.ALL | wx.EXPAND) self.BoxSizer.Add(self.RightPanel,proportion =0, border = 2,flag = wx.ALL | wx.EXPAND) self.SetSizer(self.BoxSizer) self.Center(wx.BOTH) #~ #按鈕事件,用于測(cè)試 def GetValue(self,event): self.modifiedvalues=self.IPL.GetValue() #~ print(self.modifiedvalues) return self.modifiedvalues #~ #主程序測(cè)試 def TestInputFrame(): app = wx.PySimpleApp() title='InputFrame:' label='Setting values:' values={'int':234,'String':'This is String','float':3.5} frame =InputFrame(title,label,values) frame.Show() app.MainLoop() return if __name__ == '__main__': app = wx.PySimpleApp() title='InputFrame:' label='Setting values:' values={'int':234,'String':'This is String','float':3.5} frame =InputFrame(title,label,values) frame.Show() app.MainLoop()
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- python GUI庫(kù)圖形界面開(kāi)發(fā)之PyQt5打開(kāi)保存對(duì)話框QFileDialog詳細(xì)使用方法與實(shí)例
- python GUI庫(kù)圖形界面開(kāi)發(fā)之PyQt5輸入對(duì)話框QInputDialog詳細(xì)使用方法與實(shí)例
- 基于wxPython的GUI實(shí)現(xiàn)輸入對(duì)話框(1)
- Python GUI之如何使用tkinter控件
- python制作的天氣預(yù)報(bào)小工具(gui界面)
- python 制作一個(gè)gui界面的翻譯工具
- 基于Python的EasyGUI學(xué)習(xí)實(shí)踐
- 七個(gè)Python必備的GUI庫(kù)
- python之PyAutoGui教你做個(gè)自動(dòng)腳本計(jì)算器的方法
- Python基礎(chǔ)學(xué)習(xí)之奇異的GUI對(duì)話框
相關(guān)文章
pandas中concat函數(shù)實(shí)現(xiàn)橫向連接
在pandas中,concat函數(shù)可用于合并不同的Series和DataFrame對(duì)象,本文主要介紹了pandas中concat函數(shù)實(shí)現(xiàn)橫向連接,具有一定的參考價(jià)值,感興趣的可以了解一下2024-04-04python正則表達(dá)式實(shí)現(xiàn)自動(dòng)化編程
這篇文章主要介紹了python正則表達(dá)式實(shí)現(xiàn)自動(dòng)化編程,re模塊的compile()方法是構(gòu)成正則表達(dá)式的方法,向compile()傳入一個(gè)字符串表示正則表達(dá)式,該方法返回一個(gè)Regex模式的對(duì)象,需要的朋友可以參考下2023-01-01python使用Berkeley DB數(shù)據(jù)庫(kù)實(shí)例
這篇文章主要介紹了python使用Berkeley DB數(shù)據(jù)庫(kù)的方法,以實(shí)例形式講述了完整的操作過(guò)程,并總結(jié)了具體的操作步驟,非常具有實(shí)用性,需要的朋友可以參考下2014-09-09python3 將階乘改成函數(shù)形式進(jìn)行調(diào)用的操作
這篇文章主要介紹了python3 將階乘改成函數(shù)形式進(jìn)行調(diào)用的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-03-03Python設(shè)計(jì)模式中的創(chuàng)建型工廠模式
這篇文章主要介紹了Python設(shè)計(jì)模式中的創(chuàng)建型工廠模式,工廠模式即Factory?Pattern,是提供創(chuàng)建對(duì)象的最佳方式,下文小編介紹Python工廠模式的相關(guān)資料,需要的朋友可以參考一下2022-02-02python實(shí)現(xiàn)發(fā)送帶附件的郵件代碼分享
在本篇文章里小編給大家整理的是關(guān)于python實(shí)現(xiàn)發(fā)送帶附件的郵件代碼分享內(nèi)容,需要的朋友們可以參考下。2020-09-09Python 實(shí)現(xiàn)簡(jiǎn)單的shell sed替換功能(實(shí)例講解)
下面小編就為大家?guī)?lái)一篇Python 實(shí)現(xiàn)簡(jiǎn)單的shell sed替換功能(實(shí)例講解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09