tqdm中遇到的问题

1.tqdm是什么?

https://github.com/tqdm/tqdm

简单来说,就是可以显示进度条的,它能够迭代可迭代对象。

然后又测试它是否能用枚举:

 感觉不行,打印不了进度条了。

2.例子

https://stackoverflow.com/questions/42212810/tqdm-in-jupyter-notebook-prints-new-progress-bars-repeatedly

from time import sleep
from tqdm import tqdm

values = range(3)
with tqdm(total=len(values)) as pbar:
    for i in values:
        pbar.write('processed: %d' %i)
        print('++++++++++\n')
        pbar.update(1)

 

输出:

  0%|          | 0/3 [00:00<?, ?it/s]
                                     
processed: 0

  0%|          | 0/3 [00:00<?, ?it/s]++++++++++


                                     
processed: 1

 33%|███▎      | 1/3 [00:00<00:00, 11.57it/s]++++++++++


 67%|██████▋   | 2/3 [00:00<00:00, 17.25it/s]
                                             
processed: 2

 67%|██████▋   | 2/3 [00:00<00:00, 17.25it/s]++++++++++


100%|██████████| 3/3 [00:00<00:00, 16.98it/s]

 

 为什么上面0/2会出现重复呢?

但是在jupyter中就可以发现,它是非常正常的:

 

 如果将tqdm修改为trange的话,输出也同样会有偶数的重复:

with trange(len(values)) as pbar:

输出:

  0%|          | 0/3 [00:00<?, ?it/s]
                                     
processed: 0

  0%|          | 0/3 [00:00<?, ?it/s]++++++++++


                                     
processed: 1

 33%|███▎      | 1/3 [00:00<00:00, 11.52it/s]++++++++++


 67%|██████▋   | 2/3 [00:00<00:00, 17.75it/s]
                                             
processed: 2

 67%|██████▋   | 2/3 [00:00<00:00, 17.75it/s]++++++++++


100%|██████████| 3/3 [00:00<00:00, 18.68it/s]

 

 同样在jupyter中也是非常正常的,是否是stdout和stderr的问题?

上面链接中有关于stdout和stderr的,我真的不太明白。

with tqdm(total=len(values),file=sys.stdout) as pbar:

 

如果添加到这一句的话,file进行重定向到stdout,那么输出就是蓝色的,不加的话输出就是红色的!

在idle上和jupyter上是真的不一样啊,这是怎么回事呢。这个我先放一放吧。

 

posted @ 2020-07-19 13:42  lypbendlf  阅读(1367)  评论(0编辑  收藏  举报