如何不安装额外包实现一个简单的彩色命令行进度条

13次阅读

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

如何不安装额外包实现一个简单的彩色命令行进度条

直接用 Bash 内置功能和 ANSI 转义序列就能实现一个轻量、无依赖的彩色进度条,不需要 pip 安装任何包。

核心原理:ANSI 颜色 + 回车覆盖

利用 r(回车符)将光标移至行首,配合 ANSI 颜色码(如 33[32m 表示绿色)动态刷新同一行内容。Bash 原生支持这些转义序列,无需外部工具

  • 33[32m:绿色文字
  • 33[33m:黄色文字
  • 33[31m:红色文字
  • 33[0m:重置所有样式(必须加,否则后续输出也被染色)
  • r:回到行首(不换行),用于覆盖刷新

基础版本:纯文本彩色进度条

以下是一个 10 步循环的示例,每步更新一次颜色和百分比:

for i in {1..10}; do   percent=$((i * 10))   if [ $percent -lt 50 ]; then     color="33[32m"  # 绿色(0–49%)   elif [ $percent -lt 80 ]; then     color="33[33m"  # 黄色(50–79%)   else     color="33[31m"  # 红色(80–100%)   fi   printf "r${color}[%-10s] %d%%33[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="33[32m"   elif [ $percent -le 70 ]; then     color="33[33m"   else     color="33[31m"   fi   printf "r${color}[%s] %d%%%b" "$bar" "$percent" "33[0m"   sleep 0.05 done printf "n"

注意: 是 UTF-8 字符,确保终端编码为 UTF-8(大多数现代终端默认满足);printf "%-10s" 保证栏宽稳定,防止抖动。

实用技巧与避坑提示

避免常见问题,让进度条真正可靠:

  • 始终以 33[0m 结尾,否则后续命令行被染色
  • printf 而非 echo -e,兼容性更好(尤其在不同 shell 或旧系统上)
  • 循环末尾加 printf "n",避免光标卡在行中影响后续输入
  • 如果脚本被管道或重定向(如 ./script.sh | cat),部分终端会禁用颜色——可加 [[ -t 1 ]] && use_color=1 检测是否连接到终端

text=ZqhQzanResources