可在Python终端用ANSI序列、os.system、sys.stdout.write或Windows API实现无第三方库的彩色进度条:一用\033[32;40m等转义码;二调os.system设色;三用sys.stdout.write逐字符着色;四在Windows下用ctypes调API。

如果您希望在Python终端中显示颜色进度条,但无法安装额外的第三方包(如tqdm、rich等),则可以利用ANSI转义序列直接控制终端文本颜色与样式。以下是几种不依赖外部库的实现方法:
一、使用ANSI转义序列绘制纯色进度条
ANSI转义序列是终端原生支持的颜色控制机制,通过打印特定格式的字符串即可改变后续文本的前景色、背景色及样式。该方法无需任何导入,仅需字符串拼接与系统终端兼容性保障。
1、定义绿色前景色、黑色背景色的ANSI代码:\033[32;40m;重置样式代码为:\033[0m。
2、构造进度条主体:用字符(如'█')表示已填充部分,用'░'或空格表示未填充部分。
立即学习“Python免费学习笔记(深入)”;
3、每次更新时,先打印回退光标序列:\r,再输出带颜色的进度条字符串,避免多行堆积。
4、在循环中按比例计算已填充长度,拼接着色字符与重置码,确保颜色仅作用于进度块,不污染后续输出。
二、使用os.system调用终端命令设置颜色后绘制
某些系统支持通过os.system临时修改终端默认颜色,再以普通print输出进度条。该方式将颜色设定与内容分离,适合对ANSI序列兼容性存疑的轻量环境。
1、在Linux/macOS下执行:os.system("echo -ne '\033[33m'"),将前景色设为黄色。
2、在Windows PowerShell中执行:os.system("pwsh -Command \"Write-Host -ForegroundColor Yellow ' ' -NoNewline\"")(仅限PowerShell可用)。
3、随后用常规print输出由'▓'和'▒'组成的进度条,颜色由前序命令生效。
4、进度完成时再次调用重置命令:os.system("echo -ne '3[0m'")(Linux/macOS)或等效PowerShell指令。
三、基于sys.stdout.write的逐字符着色进度条
绕过print的自动换行与缓冲干扰,直接操作标准输出流,可更精确控制每个字符的颜色状态,适用于需要高频刷新的场景。
1、导入sys模块:import sys(此为Python内置模块,不属“额外包”)。
2、对进度条每一列单独着色:例如第i列使用\033[42m \033[0m(绿色背景空格),其余列用\033[47m \033[0m(白色背景)。
3、使用sys.stdout.write()逐段写入,结尾调用sys.stdout.flush()强制刷新缓冲区。
4、每轮更新前用\r回车,保持单行动态效果。
四、利用ctypes调用Windows API设置控制台文本属性
在Windows平台下,可通过ctypes加载kernel32.dll并调用SetConsoleTextAttribute函数直接设置前景/背景色,完全脱离ANSI依赖,兼容老旧CMD环境。
1、导入ctypes与sys:import ctypes, sys(均为标准库)。
2、获取标准输出句柄:hstdout = ctypes.windll.kernel32.GetStdHandle(-11)。
3、定义颜色值常量,如绿色前景+黑色背景为0x02,红色为0x04,组合值用位或运算(如0x02 | 0x00)。
4、每次绘制前调用ctypes.windll.kernel32.SetConsoleTextAttribute(hstdout, color_value),再输出对应长度的'█'字符。










