Python tkinter進(jìn)度條控件(Progressbar)的使用
進(jìn)度條的作用就是提示用戶(hù)進(jìn)度信息??梢杂袃煞N方式:
1)提示完成度
比如,正在安裝程序的進(jìn)度,一般是從0%到100%。
2)提示正在進(jìn)行處理
比如正在處理數(shù)據(jù)內(nèi)容,并不知道何時(shí)能夠處理完畢。這個(gè)時(shí)候的進(jìn)度是提示用戶(hù)有任務(wù)正在進(jìn)行。此類(lèi)的提示沒(méi)有完成度提示,只是進(jìn)度條來(lái)回往復(fù)的移動(dòng),表示任務(wù)正在進(jìn)行中。
進(jìn)度條對(duì)象是定義在ttk中的,使用的時(shí)候需要引入ttk包。
1 屬性
屬性 | 描述 |
---|---|
cursor | 鼠標(biāo)位于進(jìn)度條內(nèi)時(shí)的形狀 |
length | 進(jìn)度條長(zhǎng)度 |
maximum | 進(jìn)度條最大刻度值 |
mode | 進(jìn)度條的模式。有兩種:‘determinate'和'indeterminate' |
orient | 進(jìn)度條的方向,有HORIZONTAL 和VERTICAL兩種 |
style | 定義進(jìn)度條的外觀 |
takefocus | 是否可以通過(guò)Tab獲得輸入焦點(diǎn) |
variable | 與進(jìn)度條關(guān)聯(lián)的變量??梢栽O(shè)置或獲得進(jìn)度條的當(dāng)前值 |
value | 設(shè)置或者獲取進(jìn)度條的當(dāng)前值 |
1.1 cursor
設(shè)置鼠標(biāo)位于進(jìn)度條內(nèi)時(shí)的形狀。具體的鼠標(biāo)形狀說(shuō)明見(jiàn)3.3.6節(jié)。
import tkinter as tk from tkinter import ttk import time def increment(*args): for i in range(100): p1["value"] = i+1 root.update() time.sleep(0.1) root = tk.Tk() root.geometry('320x240') p1 = ttk.Progressbar(root, length=200,cursor='spider', mode="determinate", orient=tk.HORIZONTAL) p1.grid(row=1,column=1) btn = ttk.Button(root,text="Start",command=increment) btn.grid(row=1,column=0) root.mainloop()
結(jié)果:
1.2 length
設(shè)置進(jìn)度條長(zhǎng)度。默認(rèn)單位是像素,也可以是其他的單位。詳細(xì)的單位說(shuō)明見(jiàn)3.3.1節(jié)。
import tkinter as tk from tkinter import ttk import time def increment(*args): for i in range(100): p1["value"] = i+1 root.update() time.sleep(0.1) root = tk.Tk() root.geometry('360x240') p1 = ttk.Progressbar(root, length='2i', mode="determinate", orient=tk.HORIZONTAL) p1.grid(row=1,column=1) btn = ttk.Button(root,text="Start",command=increment) btn.grid(row=1,column=0) root.mainloop()
說(shuō)明:長(zhǎng)度是'2i',表示是2英寸長(zhǎng)。
1.3 maximum
定義進(jìn)度條的最大刻度。默認(rèn)值是100。
import tkinter as tk from tkinter import ttk import time def increment(*args): for i in range(100): p1["value"] = i+1 root.update() time.sleep(0.1) root = tk.Tk() root.geometry('320x240') p1 = ttk.Progressbar(root, length=200, mode="determinate", maximum=200,orient=tk.HORIZONTAL) p1.grid(row=1,column=1) btn = ttk.Button(root,text="Start",command=increment) btn.grid(row=1,column=0) root.mainloop()
結(jié)果:
說(shuō)明:進(jìn)度條的最大刻度設(shè)為200,而在increment()回調(diào)函數(shù)中,只更新進(jìn)度條的數(shù)值到100。當(dāng)循環(huán)完成之后,進(jìn)度條只更新了50%的刻度。
1.4 mode
設(shè)置進(jìn)度條的模式。進(jìn)度條有兩種模式:‘determinate'和'indeterminate'
(1)determinate
對(duì)于'determinate'的模式,在程序的控制下,進(jìn)度條的指示會(huì)從0開(kāi)始,移動(dòng)到最大刻度,然后停止。這種情況用于知道確切的進(jìn)度數(shù)據(jù)。比如讀取文件,是知道文件的大小的,可以用百分比來(lái)顯示完成程度。
(2)indeterminate
對(duì)于'indeterminate',進(jìn)度條的刻度是往復(fù)運(yùn)動(dòng),表示某個(gè)處理過(guò)程正在進(jìn)行中。這種情況用于不知道確切的進(jìn)度數(shù)據(jù),也就是說(shuō),不知道完成的狀況。比如查詢(xún)數(shù)據(jù)庫(kù)返回大量的結(jié)果,程序事先無(wú)法確認(rèn)會(huì)返回多少的結(jié)果。
import tkinter as tk from tkinter import ttk import time def increment(*args): p1.start() root = tk.Tk() root.geometry('320x240') p1 = ttk.Progressbar(root, length=200, mode="indeterminate", maximum=200,orient=tk.HORIZONTAL) p1.grid(row=1,column=1) btn = ttk.Button(root,text="Start",command=increment) btn.grid(row=1,column=0) root.mainloop()
說(shuō)明:indeterminate的調(diào)用方式是使用進(jìn)度條控件的start()方法。
1.5 orient
設(shè)置進(jìn)度條的方向,有兩種格式:水平(HORIZONTAL)和垂直(VERTICAL)。
1.6 style
設(shè)置進(jìn)度條的外觀。具體的用法見(jiàn)23.2節(jié)。
1.7 takefocus
設(shè)置進(jìn)度條是否可以獲得輸入焦點(diǎn)。
1.8 variable
和進(jìn)度條有關(guān)的一個(gè)變量IntVar(),可以用來(lái)設(shè)置或者獲取進(jìn)度條當(dāng)前的數(shù)值。
1.9 value
進(jìn)度條當(dāng)前的數(shù)值。
2 函數(shù)
2.1 start(interval=None)
函數(shù) |
描述 |
---|---|
start(interval=None) |
自動(dòng)調(diào)整進(jìn)度條的位置。通過(guò)啟動(dòng)一個(gè)循環(huán)定時(shí)事件,按照定義的步長(zhǎng)調(diào)整進(jìn)度條位置。定時(shí)器的間隔由interval參數(shù)來(lái)設(shè)定。間隔單位是毫秒.默認(rèn)間隔是50毫秒。 |
step(amount=None) |
每次調(diào)整進(jìn)度條的步長(zhǎng),默認(rèn)是1.0 |
stop() |
停止定時(shí)器,停止進(jìn)度條的自動(dòng)調(diào)整 |
開(kāi)始自動(dòng)調(diào)整進(jìn)度條,默認(rèn)時(shí)間間隔是50毫秒。自動(dòng)調(diào)整是依靠啟動(dòng)一個(gè)可循環(huán)的定時(shí)器實(shí)現(xiàn)的。每次的調(diào)整步長(zhǎng)由step()函數(shù)實(shí)現(xiàn)。
2.2 step(amount=None)
定義每次調(diào)整進(jìn)度條的步長(zhǎng)。默認(rèn)是1.0,可以通過(guò)設(shè)置amount設(shè)置其他數(shù)值。
2.3 stop
停止進(jìn)度條的調(diào)整。
import tkinter as tk from tkinter import ttk import time def start(*args): p1.start(30) def stop(*args): value=p1['value'] p1.stop() p1['value']=value root = tk.Tk() root.geometry('320x240') p1 = ttk.Progressbar(root, length=200, mode="indeterminate", orient=tk.HORIZONTAL) p1.grid(row=1,column=0,columnspan=2) btn_start = ttk.Button(root,text="開(kāi)始", command=start,width=10) btn_start.grid(row=0,column=0) btn_stop = ttk.Button(root,text="停止", command=stop,width=10) btn_stop.grid(row=0,column=1) root.mainloop()
到此這篇關(guān)于Python tkinter進(jìn)度條控件(Progressbar)的使用的文章就介紹到這了,更多相關(guān)Python tkinter進(jìn)度條控件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python中的條件判斷語(yǔ)句基礎(chǔ)學(xué)習(xí)教程
這篇文章主要介紹了Python中的條件判斷語(yǔ)句基礎(chǔ)學(xué)習(xí)教程,文中使用的是Python2.x版本但條件語(yǔ)句部分的使用規(guī)則未在3.x中改變,需要的朋友可以參考下2016-02-02Python開(kāi)發(fā)之射擊闖關(guān)游戲的實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了如何利用Python實(shí)現(xiàn)射擊闖關(guān)游戲,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Python有一定的幫助,感興趣的小伙伴可以了解一下2023-01-01Python微信企業(yè)號(hào)開(kāi)發(fā)之回調(diào)模式接收微信端客戶(hù)端發(fā)送消息及被動(dòng)返回消息示例
這篇文章主要介紹了Python微信企業(yè)號(hào)開(kāi)發(fā)之回調(diào)模式接收微信端客戶(hù)端發(fā)送消息及被動(dòng)返回消息的方法,涉及Python微信企業(yè)號(hào)回調(diào)模式消息響應(yīng)機(jī)制相關(guān)操作技巧,需要的朋友可以參考下2017-08-08django inspectdb 操作已有數(shù)據(jù)庫(kù)數(shù)據(jù)的使用步驟
這篇文章主要介紹了django inspectdb 操作已有數(shù)據(jù)庫(kù)數(shù)據(jù)的使用步驟,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02Python操作數(shù)據(jù)庫(kù)之?dāng)?shù)據(jù)庫(kù)編程接口
這篇文章主要介紹了Python操作數(shù)據(jù)庫(kù)之?dāng)?shù)據(jù)庫(kù)編程接口,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下2022-06-06pytest解讀一次請(qǐng)求多個(gè)fixtures及多次請(qǐng)求
這篇文章主要為大家介紹了一次請(qǐng)求多個(gè)fixtures,以及fixtures被多次請(qǐng)求的pytest官方解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06Python實(shí)現(xiàn)測(cè)試磁盤(pán)性能的方法
這篇文章主要介紹了Python實(shí)現(xiàn)測(cè)試磁盤(pán)性能的方法,涉及Python對(duì)硬件的相關(guān)操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03Python中的 any() 函數(shù)和 all() 函數(shù)
這篇文章主要介紹了Python中的 any() 函數(shù)和 all() 函數(shù),文章基于Python的相關(guān)資料展開(kāi)對(duì) any 和 all() 函數(shù)的語(yǔ)法詳細(xì)內(nèi)容,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-04-04