码农的世界程序员python

如何让python代码显示进度信息?

2019-01-18  本文已影响4人  b4a0155c6514

今天在知乎上看问题看到有人问如何展示程序进度,之前我在写爬虫好像都是自己使用print来显示进度,对于自己写的代码我还是很熟悉的,没啥问题。但是当我们把代码交给其他人使用,如果有进度条显示会更友好一些。tqdm是一个小巧、可扩展的进度条python库,在github的star数高达8K。

学习Python中有不明白推荐加入交流群

            号:960410445
            群里有志同道合的小伙伴,互帮互助,
            群里有不错的视频学习教程和PDF!
image

安装

在命令行中的安装命令

pip install tqdm

在jupyter notebeook的Cell中的安装命令

!pip install tqdm<

一、使用

tqdm实现进度条效果有多重形式,最常用的就是下面给出的三种

1.1 基于可迭代对象

将可迭代对象放入 tqdm.tqdm函数中 , 可迭代对象长度为n,则进度条有n个进度。

from tqdm import tqdmimport time 

text = ""for char in tqdm(["a", "b"]):
    text = text + char
    time.sleep(0.5)
100%|██████████| 2/2 [00:01<00:00,  1.99it/s]
from tqdm import tqdmfor i in tqdm(range(4)):   
    pass
    time.sleep(0.5)
100%|██████████| 4/4 [00:02<00:00,  1.98it/s]

trange(i)是tqdm(range(i))的简化版

from tqdm import trangefor i in trange(5):
    pass
    time.sleep(0.5)
100%|██████████| 5/5 [00:02<00:00,  1.99it/s]

我们可以将进度条先实例化,再放到for循环体中,这样就可以做一些操作

pbar = tqdm(['a', 'b', 'c', 'd', 'e'])for char in pbar:
    pbar.set_description("程序进度 {}".format(char))
    time.sleep(0.5)
程序进度 e: 100%|██████████| 5/5 [00:02<00:00,  1.97it/s]

1.2 手动

from tqdm import tqdmwith tqdm(total=100) as pbar:
    for i in range(10): 
        pbar.update(1)  
        time.sleep(0.5)
 10%|█         | 10/100 [00:04<00:44,  2.04it/s]
from tqdm import tqdmwith tqdm(total=100) as pbar:
    for i in range(20): 
        pbar.update(1)  
        time.sleep(0.5)
 20%|██        | 20/100 [00:09<00:40,  1.99it/s]
from tqdm import tqdmwith tqdm(total=100) as pbar:
    for i in range(20): 
        pbar.update(2)  
        time.sleep(0.5)
 40%|████      | 40/100 [00:00<00:00, 129055.51it/s]

如果不适用with语句,我们记得在代码后close掉。

import time 

pbar = tqdm(total=100)for i in range(10):
    pbar.update(1)
    time.sleep(0.1)pbar.close()
 10%|█         | 10/100 [00:00<00:08, 10.03it/s]

tqdm常见参数

我们看看tqdm类的各个参数及其作用。

class tqdm(object):
  def __init__(self, iterable=None, desc=None, total=None):
import time 

pbar = tqdm(total=100)for i in range(10):
    pbar.update(1)
    time.sleep(0.1)pbar.close()
 10%|█         | 10/100 [00:00<00:09,  9.92it/s]
import time 

pbar = tqdm(total=100, desc='大邓')for i in range(10):
    pbar.update(1)
    time.sleep(0.1)pbar.close()
大邓:  10%|█         | 10/100 [00:00<00:09,  9.93it/s]
上一篇 下一篇

猜你喜欢

热点阅读