濮阳杆衣贸易有限公司

主頁 > 知識庫 > python使用PySimpleGUI設置進度條及控件使用

python使用PySimpleGUI設置進度條及控件使用

熱門標簽:打電話機器人營銷 騰訊地圖標注沒法顯示 南陽打電話機器人 商家地圖標注海報 聊城語音外呼系統(tǒng) 地圖標注自己和別人標注區(qū)別 孝感營銷電話機器人效果怎么樣 海外網(wǎng)吧地圖標注注冊 ai電銷機器人的優(yōu)勢

PySimpleGUI 使用起來感覺比tkinter要方便,當然我也沒怎么用過這兩者。只是學習模擬一下任務進度完成情況。

安裝

pip install PySimpleGUI

一、簡單進度條使用

PySimpleGUI有一個一條命令即可展示進度條的控件。one_line_progress_meter

import time
import PySimpleGUI as sg


if __name__ == '__main__':
    sg.one_line_progress_meter('進度條標題',
                               10,
                               100,
                               'key1',
                               '內容')
    # sg.one_line_progress_meter()
    time.sleep(10)

基本參數(shù)
前面的參數(shù)分別代表
進度條標題,
進度條當前進度,
進度條最大進度,
進度條的 key, (key相同代表是同一個進度條)
進度條傳入?yún)?shù)(可以是多個非關鍵字參數(shù))。

sg.one_line_progress_meter('進度條標題',
                           10,
                           100,
                           'key1',
                           '內容1')

其它常用參數(shù)orientation
由于參數(shù)*args 的存在,調用時如果希望傳入自定義參數(shù),那么前面的基本參數(shù)需要使用非關鍵字形式傳入。當然也可以不傳入自定義參數(shù)。
orientation 表示 進度條是橫向的或是縱向的。
h橫向 v縱向(默認)

 sg.one_line_progress_meter(title='進度條標題2',
                               current_value=20,
                               max_value=100,
                               key='key2',
                               orientation='h')

模擬進度條一步步填滿

import time
import PySimpleGUI as sg


if __name__ == '__main__':
    for i in range(1000):
        time.sleep(0.02)    # 模擬0.02s 完成了千分之一的任務
        sg.one_line_progress_meter(
            '進度條',
            i+1,
            1000,
            'key',
            '測試使用進度條',
            orientation='h'
        )

此處休眠時間可以當做完成任務的時間。沒完成一點任務進度條就會增加。

但實際上真正運行時有很多耗時任務執(zhí)行時會阻塞進度條。使進度條陷入未響應狀態(tài)(如第一個圖片)。所以一般會把耗時任務使用多線程執(zhí)行,執(zhí)行完成后想辦法通知進度條更新狀態(tài)。注(PySimpleGUI組件需要運行在主線程,參見源文檔說明)

one_line_progress_meter雖然方便,但樣式無法控制,其上也有很多不關心的顯示無法去除。。。

附。PySimpleGUI的彈窗使用。

sg.popup('注意!')
sg.popup_ok('默認彈窗')
sg.popup_yes_no('帶Yes和No按鈕的彈窗')
sg.popup_cancel('帶cancel按鈕的彈窗')
sg.popup_ok_cancel('帶OK和cancel按鈕的彈窗')
sg.popup_error('帶紅色error按鈕的彈窗')
sg.popup_auto_close('幾秒后自動關閉的彈窗')
sg.popup_auto_close('10秒后自動關閉的彈窗', auto_close_duration=10)

二、進度條控件使用

普通方法展示進度條控件。需要大概知曉布局和窗口的關系。

import PySimpleGUI as sg

# 布局,是一個用戶定義的二維列表。
# 第一維德元素分居不同的行上,第二維度上的元素們居于同一行,不同列上
# 此處定義的列表  由三部分組成 Text文件 ProgressBar進度條 Cancel取消按鈕構成
# Text Progress等有各自的參數(shù)設置,如size等。此處不再贅述
layout = [[sg.Text('任務完成進度')],
          [sg.ProgressBar(1000, orientation='h', size=(20, 20), key='progressbar')],
          [sg.Cancel()]]

# window只需將自定義的布局加載出來即可 第一個參數(shù)是窗口標題。
window = sg.Window('機器人執(zhí)行進度', layout)

# 根據(jù)key值獲取到進度條
progress_bar = window['progressbar']

# window的read函數(shù)分為同步和異步,
# 不帶timeout參數(shù)即為同步函數(shù) 一直等到手動點擊按鈕才會返回。
# 帶timeout參數(shù)不為None的為異步函數(shù),timeout時間內無時間或者點擊了按鈕都會產(chǎn)生結果。
# 異步方式不會阻塞后面的程序運行。
for i in range(1000):	# 循環(huán)
    event, values = window.read(timeout=10)
    if event == 'Cancel' or event is None:
        break
    progress_bar.UpdateBar(i + 1)

window.close()

此處依然是使用的for循環(huán)將進度條填滿。下面使用線程模擬任務進度完成。

三、模擬任務完成度 進度條

使用線程模擬任務進度完成。當然,沒有現(xiàn)實的任務,所以還是使用for循環(huán)加休眠組成。。。當然,與原來還是有區(qū)別的。因為任務在線程內完成,完成后需要通知主線程進度條更新。

import random
import time
from queue import Empty

import PySimpleGUI as sg
import threading
import queue

# 布局,是一個用戶定義的二維列表。
# 第一維德元素分居不同的行上,第二維度上的元素們居于同一行,不同列上
# 此處定義的列表  由三部分組成 Text文件 ProgressBar進度條 Cancel取消按鈕構成
layout = [[sg.Text('任務完成進度')],
          [sg.ProgressBar(100, orientation='h', size=(50, 20), key='progressbar')],
          [sg.Cancel()]]

# window只需將自定義的布局加載出來即可 第一個參數(shù)是窗口標題。
window = sg.Window('機器人執(zhí)行進度', layout)

# 根據(jù)key值獲取到進度條
progress_bar = window['progressbar']

# 隊列 后進先出
q = queue.Queue()


def task_1():
    global q
    for i in range(100):
        # 因為要大于window.read設置超時時間100ms 保證讀取時隊列最多只有一個元素
        time.sleep(random.random() + 0.1)
        q.put(i+1)    # 向隊列中放入當前任務完成度

# 創(chuàng)建多線程 設置以保護模式啟動,即主線程運行結束,子線程也停止運行
worker_task = threading.Thread(target=task_1)
worker_task.setDaemon(True)
worker_task.start()

while True:     # 死循環(huán)不斷讀取隊列中數(shù)據(jù),直到讀到100
    # event 就是返回的事件
    # 如點擊Cancel后    event=Cancel
    event, values = window.read(timeout=100)
    if event == 'Cancel' or event is None:
        # 點擊取消按鈕或者返回事件為 None
        break

    # 10ms 無操作算超時event會等于 __TIMEOUT__
    # 其實不用判斷
    try:
        # get是等待讀取,直到讀取到數(shù)據(jù)
        #  get_nowait 不等待,讀取不到數(shù)據(jù) 就報異常
        progress_value = q.get_nowait()
    except Empty:   # 沒有讀取到數(shù)據(jù)的話,繼續(xù)window.read
        continue
    else:   # 讀取到數(shù)據(jù)
        progress_bar.UpdateBar(progress_value)
        if progress_value == 100:   # 進度滿跳出循環(huán)
            break

window.close()

以上就是python使用PySimpleGUI設置進度條的詳細內容,更多關于python PySimpleGUI進度條的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • 6行Python代碼實現(xiàn)進度條效果(Progress、tqdm、alive-progress​​​​​​​和PySimpleGUI庫)
  • 一個非常簡單好用的Python圖形界面庫(PysimpleGUI)
  • 六種酷炫Python運行進度條效果的實現(xiàn)代碼
  • Python 給下載文件顯示進度條和下載時間的實現(xiàn)
  • Python Multiprocessing多進程 使用tqdm顯示進度條的實現(xiàn)
  • 詳細介紹Python進度條tqdm的使用
  • 在python tkinter中Canvas實現(xiàn)進度條顯示的方法
  • Python小進度條顯示代碼

標簽:楊凌 聊城 牡丹江 南寧 六盤水 撫州 揚州 迪慶

巨人網(wǎng)絡通訊聲明:本文標題《python使用PySimpleGUI設置進度條及控件使用》,本文關鍵詞  python,使用,PySimpleGUI,設置,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python使用PySimpleGUI設置進度條及控件使用》相關的同類信息!
  • 本頁收集關于python使用PySimpleGUI設置進度條及控件使用的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    和顺县| 资溪县| 连城县| 府谷县| 二连浩特市| 德格县| 正定县| 霞浦县| 铁岭县| 平潭县| 思茅市| 建水县| 乌兰浩特市| 江阴市| 华安县| 昂仁县| 兴文县| 大安市| 永安市| 芦溪县| 安达市| 大城县| 尚义县| 馆陶县| 兰考县| 涞水县| 岫岩| 平遥县| 宁陵县| 清徐县| 绥棱县| 周宁县| 独山县| 凯里市| 樟树市| 德兴市| 兴安盟| 富民县| 云梦县| 镇赉县| 磐石市|