亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

WxPython界面如何用pubsub展示進程工作的進度條

 更新時間:2022年11月01日 11:15:31   作者:陳年椰子  
這篇文章主要介紹了WxPython界面如何用pubsub展示進程工作的進度條,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

用WxPython做界面時, 如果數據操作時間比較長,會使 WxPython 界面處于假死狀態(tài),用戶體驗非常不好。

WxPython是利用pubsub來完成消息的傳送。

下面提供一個   WxPython界面利用pubsub 展示進程工作的進度條的例子,實際使用, 只要修改 

WorkThread 里的 run 內容 及 MainFrame 里的 updateDisplay 內容即可。

環(huán)境需求

Python 3.7.3
wxPython          4.0.6
Pypubsub          4.0.3

安裝 pubsub

pip install pypubsub
# encoding: utf-8
"""
@author: 陳年椰子
@contact: hndm@qq.com
@version: 1.0
@file: wxpub.py
@time: 2020/02/25  
說明  WxPython 界面利用pubsub與線程通訊使用進度條的例子
import wxpub as wp
wp.test()
"""
import wx
from pubsub import pub
from time import sleep
import threading
import sys
 
 
 
# 線程調用耗時長代碼
class WorkThread(threading.Thread):
    def __init__(self):
        """Init Worker Thread Class."""
        threading.Thread.__init__(self)
        self.breakflag = False
        self.start()
 
    def stop(self):
        self.breakflag = True
 
    # 耗時長的代碼
    def workproc(self):
        sum_x = 0
        for i in range(1, 101):
            if self.breakflag:
                pub.sendMessage("update", mstatus='中斷')
                sleep(2)
                break
            sum_x = sum_x + i
            sleep(0.1)
            pub.sendMessage("update", mstatus='計算{} , 合計 {}'.format(i, sum_x))
        return sum_x
 
    def run(self):
        """Run Worker Thread."""
        pub.sendMessage("update", mstatus='workstart')
        result = self.workproc()
        sleep(2)
        pub.sendMessage("update", mstatus='計算完成,結果 {}'.format(result))
        pub.sendMessage("update", mstatus='workdone')
 
 
 
class MainFrame(wx.Frame):
    """
    簡單的界面
    """
 
    def __init__(self, *args, **kw):
        # ensure the parent's __init__ is called
        super(MainFrame, self).__init__(*args, **kw)
 
        # create a panel in the frame
        pnl = wx.Panel(self)
 
        # and put some text with a larger bold font on it
        self.st = wx.StaticText(pnl, label="分析工具 V 2019", pos=(25,25))
        font = self.st.GetFont()
        font.PointSize += 5
        font = font.Bold()
 
        self.st.SetFont(font)
 
 
        # create a menu bar
        self.makeMenuBar()
 
        self.gauge = wx.Gauge(self, range=100, size=(300, 20))
        self.gauge.SetBezelFace(3)
        self.gauge.SetShadowWidth(3)
        sizer = wx.BoxSizer(wx.VERTICAL)
        sizer.Add(self.st, 0, wx.BOTTOM | wx.ALIGN_CENTER_VERTICAL, 0)
        sizer.Add(self.gauge, 0, wx.BOTTOM | wx.ALIGN_CENTER_VERTICAL, 0)
 
        self.SetSizer(sizer)
 
        # and a status bar
        self.CreateStatusBar()
        self.SetStatusText("啟動完成!")
 
        pub.subscribe(self.updateDisplay, "update")
 
 
 
 
    def makeMenuBar(self):
        """
        A menu bar is composed of menus, which are composed of menu items.
        This method builds a set of menus and binds handlers to be called
        when the menu item is selected.
        """
 
        # Make a file menu with Hello and Exit items
        fileMenu = wx.Menu()
        # The "\t..." syntax defines an accelerator key that also triggers
        # the same event
        # helloItem = fileMenu.Append(-1, "&Hello...\tCtrl-H",
        #         "Help string shown in status bar for this menu item")
        self.startItem = fileMenu.Append(-1, "開始",
                "開始計算")
        self.stopItem = fileMenu.Append(-1, "停止",
                                         "中斷計算")
        fileMenu.AppendSeparator()
        self.exitItem = fileMenu.Append(-1, "退出",
                "退出")
 
        # Now a help menu for the about item
        helpMenu = wx.Menu()
        aboutItem = helpMenu.Append(-1, "關于",
                "WxPython 界面與線程通訊的例子")
 
 
        # Make the menu bar and add the two menus to it. The '&' defines
        # that the next letter is the "mnemonic" for the menu item. On the
        # platforms that support it those letters are underlined and can be
        # triggered from the keyboard.
        self.menuBar = wx.MenuBar()
        self.menuBar.Append(fileMenu, "工作")
        self.menuBar.Append(helpMenu, "信息")
 
        # Give the menu bar to the frame
        self.SetMenuBar(self.menuBar)
        self.stopItem.Enable(False)
 
        self.count = 0
 
 
 
        # Finally, associate a handler function with the EVT_MENU event for
        # each of the menu items. That means that when that menu item is
        # activated then the associated handler functin will be called.
        self.Bind(wx.EVT_MENU, self.OnStart, self.startItem)
        self.Bind(wx.EVT_MENU, self.OnStop, self.stopItem)
        self.Bind(wx.EVT_MENU, self.OnExit,  self.exitItem)
        self.Bind(wx.EVT_MENU, self.OnAbout, aboutItem)
 
 
    def OnExit(self, event):
        """Close the frame, terminating the application."""
        try:
            self.work.stop()
        except:
            pass
        self.Close(True)
        sys.exit()
 
 
    def OnStart(self, event):
        self.work = WorkThread()
 
    def OnStop(self, event):
        self.work.stop()
 
 
    def OnAbout(self, event):
        """Display an About Dialog"""
        wx.MessageBox("分析工具 v2019",
                      "關于",
                      wx.OK|wx.ICON_INFORMATION)
 
    def updateDisplay(self, mstatus):
        """
        Receives data from thread and updates the display
        """
        if mstatus.find("workstart") >= 0:
            self.SetStatusText('開始計算,代碼不提供中斷線程語句,請等待計算結束!')
            self.startItem.Enable(False)
            self.stopItem.Enable(True)
            self.exitItem.Enable(False)
        if mstatus.find("workdone") >= 0:
            self.SetStatusText('完成!')
            self.stopItem.Enable(False)
            self.startItem.Enable(True)
            self.exitItem.Enable(True)
        else:
            self.st.SetLabel(mstatus)
            if mstatus.find(",")>0 and mstatus.find("計算")>=0:
                mdata = mstatus.split(',')
                # 示范 , 實際使用需要傳送進度
                # print(int(mdata[0].replace('計算','')))
                g_count = int(mdata[0].replace('計算',''))
                self.gauge.SetValue(g_count)
 
 
 
def test():
    app = wx.App()
    frm = MainFrame(None, title='分析工具')
    frm.Show()
    app.MainLoop()
 
if __name__=="__main__":
    test()

運行后, 點擊 工作-開始

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • python爬蟲之PySpider框架的使用

    python爬蟲之PySpider框架的使用

    本文主要介紹了python爬蟲之PySpider框架的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-05-05
  • 如何優(yōu)雅地處理Django中的favicon.ico圖標詳解

    如何優(yōu)雅地處理Django中的favicon.ico圖標詳解

    默認情況下,瀏覽器訪問一個網站的時候,同時還會向服務器請求"/favicon.ico"這個URL,目的是獲取網站的圖標,下面這篇文章主要給大家介紹了關于如何優(yōu)雅地處理Django中favicon.ico圖標的相關資料,需要的朋友可以參考下
    2018-07-07
  • 使用Matplotlib創(chuàng)建漂亮的數據可視化圖表

    使用Matplotlib創(chuàng)建漂亮的數據可視化圖表

    在 Python 中,Matplotlib 是一個強大而靈活的工具,可以用來創(chuàng)建各種類型的數據可視化圖表,本文給大家介紹了如何使用Matplotlib創(chuàng)建漂亮的數據可視化圖表,文中有詳細的代碼示例供大家參考,需要的朋友可以參考下
    2024-04-04
  • pytorch中tensor張量數據類型的轉化方式

    pytorch中tensor張量數據類型的轉化方式

    今天小編就為大家分享一篇pytorch中tensor張量數據類型的轉化方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • python框架flask入門之路由及簡單實現方法

    python框架flask入門之路由及簡單實現方法

    這篇文章主要介紹了python框架flask入門路由及路由簡單實現方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • 在python里協程使用同步鎖Lock的實例

    在python里協程使用同步鎖Lock的實例

    今天小編就為大家分享一篇在python里協程使用同步鎖Lock的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-02-02
  • 基于CentOS搭建Python Django環(huán)境過程解析

    基于CentOS搭建Python Django環(huán)境過程解析

    這篇文章主要介紹了基于CentOS搭建Python Django環(huán)境過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-08-08
  • python有證書的加密解密實現方法

    python有證書的加密解密實現方法

    這篇文章主要介紹了python有證書的加密解密實現方法,采用了M2Crypto組件進行相關的加密解密操作,包含了詳細的完整實現過程,需要的朋友可以參考下
    2014-11-11
  • Python開發(fā)入門之如何制作一個簡單的桌面應用

    Python開發(fā)入門之如何制作一個簡單的桌面應用

    這篇文章主要給大家介紹了關于Python開發(fā)入門之如何制作一個簡單的桌面應用的相關資料,我們不僅可以使用Python的圖像處理庫,如PIL等來實現圖片的處理和識別,同時你還可以設計和開發(fā)具有圖形界面的桌面應用程序,需要的朋友可以參考下
    2023-08-08
  • Python嵌套函數與nonlocal使用詳細介紹

    Python嵌套函數與nonlocal使用詳細介紹

    這篇文章主要介紹了Python嵌套函數與nonlocal使用,nonlocal關鍵字與global關鍵字有點相似,可以對比著理解。nonlocal關鍵字只能作用域局部變量,且始終找離當前最近的上層局部作用域中的變量
    2022-09-09

最新評論