Python控制进度条核心是实时更新显示,关键在于用\r回车覆盖、end=''防换行、flush=True强制刷新;推荐tqdm库自动适配环境并支持嵌套、手动更新与Jupyter交互式显示。

Python 中控制进度条的核心是实时更新显示内容,关键在于避免重复换行、正确覆盖上一行、适时刷新输出缓冲区。常用方法有手动控制 print + \r 和使用第三方库(如 tqdm)。
用 print + \r 手动实现简单进度条
原理是利用回车符 \r 将光标移至行首,再打印新内容覆盖旧内容,配合 end='' 防止自动换行,flush=True 强制立即输出(避免被缓冲)。
- 基本写法:
print(f'\r进度:{i}/{total} ({percent:.1f}%)', end='', flush=True) - 循环结束后建议加一个换行,防止后续输出挤在同一行:
print() - 注意:Windows 终端、主流 IDE(PyCharm、VS Code)和 Jupyter 的内核支持良好;但某些精简终端或重定向到文件时
\r可能失效
用 tqdm 库自动管理(推荐日常使用)
tqdm 封装了所有底层细节,支持嵌套、手动更新、自定义描述、估算剩余时间等,且对不同环境做了适配。
- 基础用法:
from tqdm import tqdm; for i in tqdm(range(100)): do_something() - 手动控制(如无法直接迭代):
pbar = tqdm(total=100); pbar.update(1); pbar.set_description("处理中"); pbar.close() - 支持 Jupyter:用
tqdm.notebook.tqdm获取更美观的交互式进度条 - 安装:
pip install tqdm
在多线程/多进程里安全显示进度条
多个线程/进程同时写 stdout 会导致进度条错乱。解决方案取决于场景:
立即学习“Python免费学习笔记(深入)”;
- 单任务主流程控制:把耗时操作放主线程,用
tqdm包裹其迭代器即可,无需额外同步 - 真正并行任务(如多进程下载):禁用各子进程的进度条,只在主进程汇总后统一更新一个进度条;或使用
tqdm的position和leave参数隔离各行(适合少量并行) - 不建议自行用
threading.Lock锁住 print —— 易引发死锁且破坏实时性
注意事项与常见问题
有些看似“没反应”或“乱码”的情况,往往源于环境或写法细节:
- IDE 控制台未启用“模拟终端”模式(如 PyCharm 需勾选 Emulate terminal in output console)
- 脚本输出被重定向(如
python script.py > log.txt),此时\r失效,tqdm会自动降级为静态日志 - 循环太快导致视觉闪烁:可加入
time.sleep()或仅每 N 次更新一次进度条 - Jupyter 中 print 不刷新:必须加
flush=True,或改用display/ clear_output(较复杂,一般优先选tqdm.notebook)











