可用Bash内置ANSI转义序列实现无依赖彩色进度条:用\r回车覆盖、\033[32m等设色、\033[0m重置,配合printf动态刷新;支持#或█填充、百分比变色、终端兼容性处理。

直接用 Bash 内置功能和 ANSI 转义序列就能实现一个轻量、无依赖的彩色进度条,不需要 pip 安装任何包。
核心原理:ANSI 颜色 + 回车覆盖
利用 \r(回车符)将光标移至行首,配合 ANSI 颜色码(如 \033[32m 表示绿色)动态刷新同一行内容。Bash 原生支持这些转义序列,无需外部工具。
-
\033[32m:绿色文字 -
\033[33m:黄色文字 -
\033[31m:红色文字 -
\033[0m:重置所有样式(必须加,否则后续输出也被染色) -
\r:回到行首(不换行),用于覆盖刷新
基础版本:纯文本彩色进度条
以下是一个 10 步循环的示例,每步更新一次颜色和百分比:
for i in {1..10}; do
percent=$((i * 10))
if [ $percent -lt 50 ]; then
color="\033[32m" # 绿色(0–49%)
elif [ $percent -lt 80 ]; then
color="\033[33m" # 黄色(50–79%)
else
color="\033[31m" # 红色(80–100%)
fi
printf "\r${color}[%-10s] %d%%\033[0m" $(printf "#%.0s" {1..$i}) $percent
sleep 0.3
done
printf "\n"
说明:$(printf "#%.0s" {1..$i}) 生成 i 个 #;%-10s 左对齐占位 10 字符,保持长度一致,避免残留字符。
增强版:带填充块和更顺滑的视觉效果
用 Unicode 块字符(如 █)替代 #,观感更接近专业进度条:
total=50
for i in $(seq 0 $total); do
bar=$(printf "█%.0s" $(seq 1 $((i * 10 / total)))
bar=$(printf "%-10s" "$bar") # 补空格固定宽度
percent=$((i * 100 / total))
if [ $percent -le 30 ]; then
color="\033[32m"
elif [ $percent -le 70 ]; then
color="\033[33m"
else
color="\033[31m"
fi
printf "\r${color}[%s] %d%%%b" "$bar" "$percent" "\033[0m"
sleep 0.05
done
printf "\n"
注意:█ 是 UTF-8 字符,确保终端编码为 UTF-8(大多数现代终端默认满足);printf "%-10s" 保证栏宽稳定,防止抖动。
实用技巧与避坑提示
避免常见问题,让进度条真正可靠:
- 始终以
\033[0m结尾,否则后续命令行被染色 - 用
printf而非echo -e,兼容性更好(尤其在不同 shell 或旧系统上) - 循环末尾加
printf "\n",避免光标卡在行中影响后续输入 - 如果脚本被管道或重定向(如
./script.sh | cat),部分终端会禁用颜色——可加[[ -t 1 ]] && use_color=1检测是否连接到终端










