【问题标题】:tqdm - multiple progress bars with nested for loops in PyCharmtqdm - PyCharm 中带有嵌套 for 循环的多个进度条
【发布时间】:2021-02-19 22:17:42
【问题描述】:

以下问题适用于使用 PyCharm 的人。 有嵌套的for 循环,tqdm 用于每个for 循环对应的进度条。代码如下所示。

from tqdm import tqdm
import time

for i in tqdm(range(5), desc="i", colour='green'):
    for j in tqdm(range(10), desc="j", colour='red'):
        time.sleep(0.5)

但问题是,每次更新时,内循环的进度条都会出现在换行符中,如下所示。

i:   0%|          | 0/5 [00:00<?, ?it/s]
j:   0%|          | 0/10 [00:00<?, ?it/s]
j:  10%|█         | 1/10 [00:00<00:04,  1.94it/s]
j:  20%|██        | 2/10 [00:01<00:04,  1.94it/s]
j:  30%|███       | 3/10 [00:01<00:03,  1.96it/s]
j:  40%|████      | 4/10 [00:02<00:03,  1.96it/s]
j:  50%|█████     | 5/10 [00:02<00:02,  1.97it/s]
j:  60%|██████    | 6/10 [00:03<00:02,  1.97it/s]
j:  70%|███████   | 7/10 [00:03<00:01,  1.97it/s]
j:  80%|████████  | 8/10 [00:04<00:01,  1.98it/s]
j:  90%|█████████ | 9/10 [00:04<00:00,  1.98it/s]
j: 100%|██████████| 10/10 [00:05<00:00,  1.98it/s]
i:  20%|██        | 1/5 [00:05<00:20,  5.06s/it]
j:   0%|          | 0/10 [00:00<?, ?it/s]
j:  10%|█         | 1/10 [00:00<00:04,  2.00it/s]
j:  20%|██        | 2/10 [00:01<00:04,  1.99it/s]
j:  30%|███       | 3/10 [00:01<00:03,  1.99it/s]
j:  40%|████      | 4/10 [00:02<00:03,  1.99it/s]
j:  50%|█████     | 5/10 [00:02<00:02,  1.99it/s]
j:  60%|██████    | 6/10 [00:03<00:02,  1.99it/s]
j:  70%|███████   | 7/10 [00:03<00:01,  1.99it/s]
j:  80%|████████  | 8/10 [00:04<00:01,  1.99it/s]
j:  90%|█████████ | 9/10 [00:04<00:00,  1.99it/s]
j: 100%|██████████| 10/10 [00:05<00:00,  1.99it/s]
i:  40%|████      | 2/5 [00:10<00:15,  5.05s/it]

为每个循环设置参数“位置”也不能解决问题。

from tqdm import tqdm
import time

for i in tqdm(range(5), desc="i", colour='green', position=0):
    for j in tqdm(range(10), desc="j", colour='red', position=1):
        time.sleep(0.5)

如何让进度条在同一行更新?

【问题讨论】:

    标签: python pycharm tqdm


    【解决方案1】:

    解决方案有两个。

    1. 转到“编辑配置”。单击正在使用的运行/调试配置。应该有一个选项“在输出控制台中模拟终端”。检查那个。添加图片以供参考。

    2. 除了position 参数,还要设置leave 参数。代码应如下所示。我添加了ncols,这样进度条就不会占据整个控制台。

    from tqdm import tqdm
    import time
    
    for i in tqdm(range(5), position=0, desc="i", leave=False, colour='green', ncols=80):
        for j in tqdm(range(10), position=1, desc="j", leave=False, colour='red', ncols=80):
            time.sleep(0.5)
    

    现在运行代码时,控制台的输出如下图所示。

    i:  20%|████████▍                                 | 1/5 [00:05<00:20,  5.10s/it]
    j:  60%|████████████████████████▌                | 6/10 [00:03<00:02,  1.95it/s]
    
    

    更新发生在同一行。

    【讨论】:

    • 很遗憾,使用 ssh 解释器 (2020.3) 时,此复选框不存在
    • @cr0 这个问题已经被提出here。由开发人员提供此选项。
    猜你喜欢
    • 1970-01-01
    • 2020-07-10
    • 1970-01-01
    • 2015-10-15
    • 1970-01-01
    • 1970-01-01
    • 2018-01-30
    • 2021-08-21
    • 2021-07-07
    相关资源
    最近更新 更多