• python实现进度条的方法和实现代码


    在Python中,有多种方式可以实现进度条。这里,我将介绍七种常见的方法:使用tqdm(这是一个外部库,非常流行且易于使用)、rich、click、progressbar2等库以及纯Python的print函数与time库来模拟进度条。

    目录

    一、使用tqdm库

    二、使用纯Python实现

    三、使用rich库

    四、使用click库 

    五、使用progressbar2库

    六、使用PySimpleGUI库 

    七、使用curses库(Unix/Linux)


    一、使用tqdm

    首先,你需要安装tqdm库。你可以使用pip来安装:

    pip install tqdm

    然后,你可以使用以下代码来显示进度条: 

    1. from tqdm import tqdm
    2. import time
    3. # 模拟一个需要花费时间的任务
    4. for i in tqdm(range(100)):
    5. time.sleep(0.01) # 假设每个迭代需要0.01秒

    在这个例子中,tqdm会自动处理进度条的显示,你不需要做其他任何事情。每次迭代时,进度条都会更新。 

    效果:

    10%|█         | 10/100 [00:01<00:09,  9.98it/s]

    二、使用纯Python实现

    如果你不想使用外部库,你也可以使用Python的print函数和time库来模拟一个简单的进度条。但是请注意,这种方法没有tqdm那么灵活和强大。

    以下是一个简单的例子:

    1. import time
    2. import sys
    3. def print_progress_bar(iteration, total, prefix='', suffix='', decimals=1, length=100, fill='█', printEnd="\r"):
    4. """
    5. Call in a loop to create terminal progress bar
    6. @params:
    7. iteration - Required : current iteration (Int)
    8. total - Required : total iterations (Int)
    9. prefix - Optional : prefix string (Str)
    10. suffix - Optional : suffix string (Str)
    11. decimals - Optional : positive number of decimals in percent complete (Int)
    12. length - Optional : character length of bar (Int)
    13. fill - Optional : bar fill character (Str)
    14. printEnd - Optional : end character (e.g. "\r", "\r\n") (Str)
    15. """
    16. percent = ("{0:." + str(decimals) + "f}").format(100 * (iteration / float(total)))
    17. filledLength = int(length * iteration // total)
    18. bar = fill * filledLength + '-' * (length - filledLength)
    19. print(f'\r{prefix} |{bar}| {percent}% {suffix}', end=printEnd)
    20. # Print New Line on Complete
    21. if iteration == total:
    22. print()
    23. # 模拟一个需要花费时间的任务
    24. for i in range(100):
    25. time.sleep(0.01) # 假设每个迭代需要0.01秒
    26. print_progress_bar(i + 1, 100, prefix='Progress:', suffix='Complete', length=50)

    在这个例子中,print_progress_bar函数用于打印进度条。它接受当前迭代次数、总迭代次数和其他一些可选参数。在每次迭代中,我们调用这个函数来更新进度条。注意,我们在循环结束后添加了一个额外的换行符,以便在进度条完成后清除终端中的最后一行。 

    除了使用tqdm库和纯Python的print函数与time库来模拟进度条之外,还有其他几种方法可以实现进度条。这里我将介绍两种额外的方法:

    三、使用rich

    rich库是一个用于创建丰富文本和漂亮终端输出的Python库,它也包括了一个强大的进度条功能。

    首先,你需要安装rich库:

    pip install rich

    然后,你可以使用以下代码来显示进度条: 

    1. from rich.progress import Progress
    2. import time
    3. with Progress() as progress:
    4. task = progress.add_task("Processing...", total=100)
    5. for i in range(100):
    6. time.sleep(0.01) # 假设每个迭代需要0.01秒
    7. progress.update(task, advance=1)

    效果:

    Processing... ███████████▏                                  50/100 [00:04<00:04, 11.97it/s]

     

    四、使用click库 

    click库是一个用于创建命令行接口的库,它也提供了一个简单的进度条实现。

    首先,你需要安装click库:

    pip install click

    但是,请注意,click的进度条主要用于命令行工具,并且可能不如tqdmrich那么灵活。不过,如果你正在开发一个命令行工具,它可能是个不错的选择。

    以下是一个使用click库的简单示例:

    1. import click
    2. import time
    3. @click.command()
    4. def cli():
    5. with click.progressbar(range(100)) as bar:
    6. for item in bar:
    7. time.sleep(0.01) # 假设每个迭代需要0.01秒
    8. if __name__ == '__main__':
    9. cli()

    在这个例子中,我们定义了一个cli函数,并使用click.progressbar上下文管理器来包装一个范围。在每次迭代中,进度条会自动更新。

    以上介绍了四种不同的方法来实现Python中的进度条:使用tqdm库、纯Python的print函数与time库、rich库和click库。每种方法都有其优缺点,你可以根据你的具体需求来选择最适合你的方法。如果你需要一个简单且易于使用的库,tqdm可能是一个很好的选择。如果你需要更丰富的终端输出和更多的控制选项,rich可能更适合你。如果你正在开发一个命令行工具,并且需要进度条功能,那么click可能是一个好选择。

    当然,还有其他方法可以实现Python中的进度条,尽管它们可能不如前面提到的库那样全面或易于使用。以下是一些额外的方法:

    五、使用progressbar2

    progressbar2是另一个流行的库,用于在Python中创建进度条。虽然它的功能可能与tqdm相似,但如果你更喜欢这个库,可以尝试使用它。

    首先,你需要安装progressbar2库:

    pip install progressbar2

    然后,你可以使用以下代码来显示进度条: 

    1. from progressbar import ProgressBar
    2. import time
    3. bar = ProgressBar(max_value=100)
    4. for i in range(100):
    5. time.sleep(0.01) # 假设每个迭代需要0.01秒
    6. bar.update(i + 1)
    7. bar.finish()

    六、使用PySimpleGUI库 

    PySimpleGUI是一个用于创建图形用户界面(GUI)的库,但它也支持在控制台应用程序中显示进度条。这个库非常适合那些希望在控制台应用程序中添加更多交互性的用户。

    首先,你需要安装PySimpleGUI库:

    pip install pysimplegui

    然后,你可以使用以下代码来显示一个控制台进度条:

    1. import PySimpleGUI as sg
    2. import time
    3. # 创建一个进度条元素
    4. progress_bar = sg.ProgressBar(100, orientation='h', size=(50, 15), key='progressbar')
    5. # 创建一个窗口,其中包含进度条
    6. layout = [[progress_bar]]
    7. window = sg.Window('Progress Bar', layout)
    8. # 启动事件循环
    9. for i in range(101):
    10. event, values = window.read(timeout=100)
    11. progress_bar.update_bar(i + 1)
    12. time.sleep(0.01) # 假设每个迭代需要0.01秒
    13. # 关闭窗口
    14. window.close()

    七、使用curses库(Unix/Linux)

    在Unix和Linux系统上,你可以使用curses库来创建文本用户界面,包括进度条。但是,请注意,curses库在Windows上不可用。

    首先,你需要确保你的系统上安装了curses库(在大多数Linux发行版上都是预装的)。然后,你可以使用以下代码来显示一个基本的进度条:

    1. import curses
    2. import time
    3. def main(stdscr):
    4. # 清除屏幕
    5. stdscr.clear()
    6. # 初始化颜色对(可选)
    7. curses.start_color()
    8. curses.init_pair(1, curses.COLOR_GREEN, curses.COLOR_BLACK)
    9. # 创建一个进度条窗口
    10. height, width = stdscr.getmaxyx()
    11. progress_bar_width = 50
    12. progress_bar_start = (height // 2) - 1
    13. progress_bar_end = progress_bar_start + 1
    14. for i in range(101):
    15. # 清除进度条行
    16. stdscr.addstr(progress_bar_start, 0, ' ' * width)
    17. # 计算并显示进度条
    18. filled_length = int((i / 100.0) * progress_bar_width)
    19. stdscr.addstr(progress_bar_start, (width - progress_bar_width) // 2, '[' + '=' * filled_length + ' ' * (progress_bar_width - filled_length) + ']')
    20. # 刷新屏幕以显示更新
    21. stdscr.refresh()
    22. # 模拟进度
    23. time.sleep(0.01)
    24. # 等待用户按键退出
    25. stdscr.getkey()
    26. # 使用curses包装器运行main函数
    27. curses.wrapper(main)

    这些方法提供了不同的方式来在Python中创建和显示进度条,你可以根据你的具体需求和目标平台来选择最适合你的方法。 

  • 相关阅读:
    【PowerQuery】Excel的PowerQuery按需刷新
    半导体二极管
    内衣洗衣机便宜好用的牌子有哪些?四款公认好用洗内裤机推荐
    react create-react-app v5配置 px2rem (暴露 eject方式)
    20个Golang最佳实践
    vue3路由跳转传参
    【电气安全】安科瑞电气火灾监控系统在江苏某大学中设计与应用
    CSS3提高: CSS3 3D转换
    【Python】Numpy生成坐标网格
    万物互联时代到来,猿代码领衔先计算机赋数据化转型
  • 原文地址:https://blog.csdn.net/weixin_43734080/article/details/139814913