Tkinter使用Progressbar创建和管理进度条的操作代码

 更新时间:2023年07月12日 16:37:39   作者:檬柠wan  
Progressbar是Tkinter库中的一个小部件,用于创建和管理进度条,这篇文章主要介绍了Tkinter使用Progressbar创建和管理进度条,本文结合实例代码给大家介绍的非常详细,需要的朋友可以参考下

前言

Progressbar是Tkinter库中的一个小部件,用于创建和管理进度条。它可以在图形用户界面中显示任务的进度,并提供了多种样式和配置选项。

使用Progressbar,你可以按照固定或不确定的进度展示任务的进行状态。它可以显示任务完成的百分比,或者在不确定的情况下,显示一个动画效果表示任务正在进行。

以下是一些Progressbar的重要属性和方法:

  • length:指定进度条的长度。
  • mode:指定进度条的模式,可以是"determinate"(确定模式)或"indeterminate"(不确定模式)。
  • maximum:设置进度条的最大值,默认为100。
  • value:设置进度条的当前值。
  • start():启动进度条的动画效果,仅在不确定模式下有效。
  • stop():停止进度条的动画效果,仅在不确定模式下有效。

通过使用这些属性和方法,你可以创建一个自定义的进度条并根据需要进行更新和控制。

一、indeterminate 模式

在这个模式下指针左右移动,主要目的是要让用户知道程序还在运行

import tkinter as tk
from tkinter.ttk import Progressbar
class Simulate_Waiting_State:
    def __init__(self):
        self.root = tk.Tk()
        self.root.title('进度条下载演示')
        self.root.geometry("300x150+1100+150")
        self.interface()
    def interface(self):
        # 创建进度条
        self.progress_bar = Progressbar(self.root, length=200, mode="indeterminate")
        # 创建按钮
        self.start_button = tk.Button(self.root, text="开始", command=self.start_progress)
        self.stop_button = tk.Button(self.root, text="停止", command=self.stop_progress)
        # 将进度条和按钮放置在窗口中
        self.progress_bar.grid(row=0, column=1, pady=20, padx=50, columnspan=100)
        self.start_button.grid(row=1, column=1, padx=75)
        self.stop_button.grid(row=1, column=3)
    def start_progress(self):
        self.progress_bar.start()
    def stop_progress(self):
        self.progress_bar.stop()
if __name__ == '__main__':
    run = Simulate_Waiting_State()
    run.root.mainloop()
import tkinter as tk
from tkinter.ttk import Progressbar
class Simulate_Waiting_State:
    def __init__(self):
        self.root = tk.Tk()
        self.root.title('进度条下载演示')
        self.root.geometry("300x150+1100+150")
        self.interface()
    def interface(self):
        # 创建进度条
        self.progress_bar = Progressbar(self.root, length=200, mode="indeterminate")
        # 创建按钮
        self.start_button = tk.Button(self.root, text="开始", command=self.start_progress)
        self.stop_button = tk.Button(self.root, text="停止", command=self.stop_progress)
        # 将进度条和按钮放置在窗口中
        self.progress_bar.grid(row=0, column=1, pady=20, padx=50, columnspan=100)
        self.start_button.grid(row=1, column=1, padx=75)
        self.stop_button.grid(row=1, column=3)
    def start_progress(self):
        self.progress_bar.start()
    def stop_progress(self):
        self.progress_bar.stop()
if __name__ == '__main__':
    run = Simulate_Waiting_State()
    run.root.mainloop()

请添加图片描述

二、determinate模式

1、模拟下载进度

import tkinter as tk
from tkinter.ttk import Progressbar
import threading
import time
class Download_Files:
    def __init__(self):
        self.root = tk.Tk()
        self.root.title('进度条下载演示')
        self.root.geometry("300x150+1100+150")
        self.interface()
    def interface(self):
        # 创建进度条
        self.progress_bar = Progressbar(self.root, length=200, mode="determinate")
        # 创建按钮
        self.start_button = tk.Button(self.root, text="开始下载", command=self.download)
        # 将进度条和按钮放置在窗口中
        self.progress_bar.grid(row=0, pady=20, padx=50)
        self.start_button.grid(row=1, padx=50)
        # 进度值最大值
        self.progress_bar['maximum'] = 100
    def download(self):
        """进度条模拟显示下载进度"""
        # 进度值初始值
        initial_value = 0
        while initial_value < 100:
            initial_value += 1
            # 更新进度条的值
            self.progress_bar['value'] = initial_value
            self.root.update()
            # 模拟等待时间时间
            time.sleep(0.1)
    def thread_management(self):
        """启用子线程下载文件"""
        T1 = threading.Thread(target=self.download, daemon=True)
        T1.start()
if __name__ == '__main__':
    run = Download_Files()
    run.root.mainloop()

2、真实下载进度

import tkinter as tk
from tkinter.ttk import Progressbar
from tkinter import messagebox
import threading
import requests
class Download_Files:
    def __init__(self):
        self.root = tk.Tk()
        self.root.title('进度条下载演示')
        self.root.geometry("300x150+850+350")
        self.interface()
    def interface(self):
        # 创建进度条
        self.progress_bar = Progressbar(self.root, length=200, mode="determinate")
        # 创建按钮
        self.start_button = tk.Button(self.root, text="开始下载", command=self.thread_group)
        # 将进度条和按钮放置在窗口中
        self.progress_bar.grid(row=0, pady=20, padx=50)
        self.start_button.grid(row=1, padx=50)
    def download(self):
        # 禁用按钮
        self.start_button.config(state=tk.DISABLED)
        # 下载地址
        url = 'http://www.python.org/ftp/python/2.7.5/Python-2.7.5.tar.bz2'
        file_data = requests.get(url, stream=True)
        # 获取文件大小,单位字节(B)
        if "content-length" in file_data.headers:
            maxbyte = int(file_data.headers["content-length"])
        # 截取文件名称
        filename = url.split("/")[-1]
        with open(filename, "wb") as f:
            downloaded_bytes = 0
            for chunk in file_data.iter_content(chunk_size=1024):
                if chunk:
                    f.write(chunk)
                    downloaded_bytes += len(chunk)
                    # 更新进度条的值
                    # 将已下载的字节数除以文件总大小(maxbyte),然后乘以100,得到已下载的数据量相对于文件总大小的百分比
                    self.progress_bar['value'] = downloaded_bytes / maxbyte * 100
                    self.root.update()
        # 弹窗提示下载完成
        messagebox.showinfo("下载提示", "文件下载完成!")
        # 恢复按钮的可点击状态
        self.start_button.config(state=tk.NORMAL)
        # 下载完成后重置进度条的值
        self.progress_bar['value'] = 0
    def thread_group(self):
        """启用子线程下载"""
        T1 = threading.Thread(name='download', target=self.download, daemon=True)
        T1.start()
if __name__ == '__main__':
    run = Download_Files()
    run.root.mainloop()

请添加图片描述

到此这篇关于Tkinter使用Progressbar创建和管理进度条的文章就介绍到这了,更多相关Tkinter Progressbar进度条内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python使用JWT的超详细教程

    Python使用JWT的超详细教程

    这篇文章主要介绍了Python使用JWT的相关资料,JWT(JSON Web Tokens)是一种网络应用间传输信息的标准,包括三部分:Header(头部),Payload(负载),Signature(签名),头部包含声明类型和算法,需要的朋友可以参考下
    2024-10-10
  • Python关于__name__属性的含义和作用详解

    Python关于__name__属性的含义和作用详解

    在本篇文章里小编给大家分享的是关于Python关于__name__属性的含义和作用知识点,需要的朋友们可以参考下。
    2020-02-02
  • 解决python明明pip安装成功却找不到包的问题

    解决python明明pip安装成功却找不到包的问题

    今天小编就为大家分享一篇解决python明明pip安装成功却找不到包的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-08-08
  • Python中的装饰器链(decorator chain)详解

    Python中的装饰器链(decorator chain)详解

    在Python中,装饰器是一种高级功能,它允许你在不修改函数或类代码的情况下,为它们添加额外的功能,装饰器通常用于日志记录、性能测量、权限检查等场景,当多个装饰器应用于同一个函数或类时,形成装饰器链,这篇文章主要介绍了Python中的装饰器链详解,需要的朋友可以参考下
    2024-06-06
  • 基于Python函数的作用域规则和闭包(详解)

    基于Python函数的作用域规则和闭包(详解)

    下面小编就为大家分享一篇基于Python函数的作用域规则和闭包详解,希望对大家有所帮助。一起跟随小编过来看看吧
    2017-11-11
  • Python趣味挑战之用pygame实现简单的金币旋转效果

    Python趣味挑战之用pygame实现简单的金币旋转效果

    今天教大家怎么用pygame实现简单的金币旋转效果,文中有非常详细的代码示例,对正在学习python的小伙伴们很有帮助,需要的朋友可以参考下
    2021-05-05
  • Python实现图像尺寸和格式转换处理的示例详解

    Python实现图像尺寸和格式转换处理的示例详解

    这篇文章主要为大家详细介绍了如何利用Python实现图像尺寸获取和格式转换处理的功能,文中的示例代码讲解详细,感兴趣的可以了解一下
    2023-04-04
  • Python可视化神器pyecharts绘制漏斗图

    Python可视化神器pyecharts绘制漏斗图

    这篇文章主要介绍了Python可视化神器pyecharts绘制漏斗图,漏斗图是由Light等在1984年提出,一般以单个研究的效应量为横坐标,样本含量为纵坐标做的散点图
    2022-07-07
  • Python3实时操作处理日志文件的实现

    Python3实时操作处理日志文件的实现

    本文主要介绍了Python3实时操作处理日志文件的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • Python内置函数map()的具体使用

    Python内置函数map()的具体使用

    Python中的map()函数是一个高效的内置函数,用于将指定函数应用于序列的每个元素,通过接收一个函数和一个或多个序列,本文就来详细的介绍一下如何使用,感兴趣的可以了解一下
    2024-09-09

最新评论