Python tkinter 控件更新信息

下面几个例子关于tkinter界面更新的,简单易懂,分享一下。

  • 例子_1:

  • 代码_1:
from tkinter import Tk, Checkbutton, Label
from tkinter import StringVar, IntVar

root = Tk()

text = StringVar()
text.set(‘old‘)
status = IntVar()

def change():
    if status.get() == 1:   # if clicked
        text.set(‘new‘)
    else:
        text.set(‘old‘)

cb = Checkbutton(root, variable=status, command=change)
lb = Label(root, textvariable=text)
cb.pack()
lb.pack()

root.mainloop()
  • 例子_2:

  • 代码_2:
from tkinter import *
import time

class StopWatch(Frame):
    ‘‘‘实现一个秒表部件‘‘‘
    msec = 50
    def __init__(self, parent=None, **kw):
        Frame.__init__(self, parent, kw)
        self._start = 0.0
        self._elapsedtime = 0.0
        self._running = False
        self.timestr = StringVar()
        self.makeWidgets()
        self.flag  = True
    def makeWidgets(self):
        ‘‘‘制作时间标签‘‘‘
        l = Label(self, textvariable = self.timestr)
        self._setTime(self._elapsedtime)
        l.pack(fill = X, expand = NO, pady = 2, padx = 2)
    def _update(self):
        self._elapsedtime = time.time() - self._start
        self._setTime(self._elapsedtime)
        self._timer = self.after(self.msec, self._update)
    def _setTime(self, elap):
        ‘‘‘将时间格式改为 分:秒:百分秒‘‘‘
        minutes = int(elap/60)
        seconds = int(elap-minutes*60.0)
        hseconds = int((elap - minutes*60.0 - seconds) *100)
        self.timestr.set(‘%2d:%2d:%2d‘ %(minutes, seconds, hseconds))
    def Start(self):
        if not self._running:
            self._start = time.time() - self._elapsedtime
            self._update()
            self._running = True
    def Stop(self):
        ‘‘‘停止秒表‘‘‘
        if self._running:
            self.after_cancel(self._timer)
            self._elapsedtime = time.time() - self._start
            self._setTime(self._elapsedtime)
            self._running = False
    def Reset(self):
        ‘‘‘重设秒表‘‘‘
        self._start = time.time()
        self._elapsedtime = 0.0
        self._setTime(self._elapsedtime)

    def stopwatch(self):
        if self.flag == True:
            self.pack(side = TOP)
            Button(self, text = ‘start‘, command = self.Start).pack(side = LEFT)
            Button(self, text = ‘stop‘, command = self.Stop).pack(side = LEFT)
            Button(self, text = ‘reset‘, command = self.Reset).pack(side = LEFT)
            Button(self, text = ‘quit‘, command = self.quit).pack(side = LEFT)
        self.flag = False

class Watch(Frame):
    msec = 1000
    def __init__(self, parent=None, **kw):
            Frame.__init__(self, parent, kw)
            self._running = False
            self.timestr1 = StringVar()
            self.timestr2 = StringVar()
            self.makeWidgets()
            self.flag  = True
    def makeWidgets(self):
        l1 = Label(self, textvariable = self.timestr1)
        l2 = Label(self, textvariable = self.timestr2)
        l1.pack()
        l2.pack()
    def _update(self):
        self._settime()
        self.timer = self.after(self.msec, self._update)
    def _settime(self):
        today1 = str(time.strftime(‘%Y-%m-%d‘, time.localtime(time.time())))
        time1 = str(time.strftime(‘%H:%M:%S‘, time.localtime(time.time())))
        self.timestr1.set(today1)
        self.timestr2.set(time1)
    def start(self):
        self._update()
        self.pack(side = TOP)

if __name__ == ‘__main__‘:
    def main():
        root = Tk()
        root.geometry(‘250x150‘)
        frame1 = Frame(root)
        frame1.pack(side = BOTTOM)
        sw = StopWatch(root)
        stpwtch = Button(frame1, text = ‘秒表‘, command = sw.stopwatch)
        stpwtch.pack(side = RIGHT)
        mw = Watch(root)
        mywatch = Button(frame1, text = ‘时钟‘, command = mw.start)
        mywatch.pack(side = LEFT)
        root.mainloop()
    main()

原文地址:https://www.cnblogs.com/hackpig/p/8206532.html

时间: 2024-11-06 03:41:44

Python tkinter 控件更新信息的相关文章

python tkinter 控件与布局 项目实战

代码部分: from tkinter import * import tkinter.messagebox as messagebox class Tkdemo(): def __init__(self): master = Tk() master.title("missWjz") master.geometry('800x800') #创建菜单栏 menubar = Menu(master) master.config(menu=menubar) #创建下拉菜单栏 filemenu

Tkinter控件学习总结(一)

此部分总结只涉及基本UI布局.按钮点击回调.控件中用户输入内容的获取等,并不涉及键盘事件.鼠标事件的获取等等. (一)Tkinter的优缺点 Tkinter是Python自带的GUI库,它最好的一个优点就是不用另外装额外 的库拿来就可以用了,而且整个库很小巧,入门简单,这很适合于只想集中精力解决实际问题的人. 如果是作一些简单的界面,Tkinter已经足够胜任.不过对于我来说,它有个致命的缺点就是不支持对png格式文件的显示.其实使用python的image库是可以解析png格式文件的.但我拿一

C#如何解决对ListView控件更新以及更新时界面闪烁问题

第一个问题:如何更新ListView控件内容 很多时候运行窗体程序时,由于程序中使用了多线程加之操作不当,所以在对控件操作时会出现下面这样的异常: 这是因为我们在窗体中添加的控件都有属于自己的线程,所以不能从其它线程来访问它. 那要如何解决? 使用委托:MethodInvoker,我用这个挺方便的.下面举一个用例: 1 //调用InitListView(),便可以对ListView控件进行自由更新啦 2 private void InitListView() 3 { 4 MethodInvoke

在子线程中更改主线程中的控件的信息,在子线程中用toast

一丶在子线程中不允许更改主线程中的控件的信息,也不允许在子线程中用toast,我们要更改的话 (1)消息机制:使用handler (由主线程调用) 在主程序中Handler handler = new Handler(){ public void handleMessage(Message msg){ int type = msg.what ;//拿到msg的类型,再判断            switch (type) {                case SUCCESS:      

DevExpress的GridControl控件更新數據問題解決辦法

開發WPF程序時,使用Devexpress的GridControl控件用ItemSource綁定數據,在頁面進行編輯時,當屬性繼承INotifyPropertyChanged接口時會同步更新後臺數據.今天在開發時遇到一種情況,當通過GridControl中Row上Button[Command]改變行內數據,也就是binding的Detail數據已改變,這時NotifyPropertyChanged有觸發,但改變的行數據不會同步更新到UI上,目前測試有兩種方式進行解決. 1.直接new 一個新的行

[Python] wx python 基本控件 (转)

转自:http://www.cnblogs.com/wangjian8888/p/6028777.html 一.静态文本控件 wx.StaticText(parent, id, label, pos=wx.DefaultPosition,    size=wx.DefaultSize, style=0, name="staticText") wx.StaticText构造函数的参数 parent:父窗口部件. id:标识符.使用-1可以自动创建一个唯一的标识. label:你想显示在静

云存储上传控件更新日志-Xproer.HttpUploader7

官方网站:http://www.ncmem.com/ 产品首页:http://www.ncmem.com/webplug/http-uploader7/index.asp 在线演示:http://www.ncmem.com/products/http-uploader6/index.html 产品介绍:http://www.cnblogs.com/xproer/p/4744468.html 升级日志:http://www.cnblogs.com/xproer/archive/2012/10/26

解决UI控件更新不及时问题

有时候我们会在开发过程中发现某个控件出现更新不及时问题,如:某个Button明明设置了frame但是其位置和尺寸并没有改变需要点击一下的时候才会更新,又或者一个Label已经设置了一个新的text,但是内容还是旧的等等这类的现象.起初以为是因为自己没有调用setNeedDisplay或者setNeedLayout方法导致更新不及时.后来才发现是因为UI的操作没有在主线程调用所导致的问题. 因此,如果在某个方法中存在UI操作,如果没有把握认定这个操作是在主线程中执行的话,那么可以通过GCD在方法中

一个在SOUI中加速自适应大小的控件更新的小技巧

在SOUI中的控件有指定大小和自适应大小两类控件. 指定大小的控件,在控件内容更新时不需要重新布局,而自适应大小的控件在内容变化后会导致父窗口重新布局. 最近有网友发现在高速批量更新一个窗口的自适应控件(如50次/S的速度批量更新30个文件控件)时,SOUI的性能很低. 跟踪发现导致这个问题的关键在于在一次刷新过程中,每更新一个控件就需要执行一次重新布局,显而易见,这种情况下效率是非常低的. 解决这个问题的方法有两种: 一个简单的方法就是将自适应大小的文本控件改成固定大小的文本控件,如此,在定时