Jupyter中print()默认支持ANSI转义序列,需内核支持且输出未被重定向;现代JupyterLab和Notebook默认启用,可直接打印彩色文字,但须以\033[0m重置样式。

在 Jupyter 中,print() 默认能显示 ANSI 转义序列(如 \033[31m红色\033[0m),但需满足两个前提:内核支持 ANSI、输出未被截断或重定向。多数现代 Jupyter(含 JupyterLab 和经典 Notebook)默认启用 ANSI 渲染,无需额外配置。
确认终端/前端是否支持 ANSI
Jupyter 的输出区域本质是富文本渲染器,它会解析并应用常见 ANSI 颜色代码(如前景色 \033[32m、背景色 \033[44m、样式 \033[1m)。只要不是用 sys.stdout = StringIO() 之类方式重定向了标准输出,直接 print 就生效。
- ✅ 支持的典型代码:
print("\033[33m黄色文字\033[0m") - ⚠️ 注意:
\033[0m必须结尾重置样式,否则后续所有输出都带颜色 - ❌ 不支持的场景:某些旧版 IPython 内核(--no-color 启动参数时会禁用
用 colorama 或 rich 简化跨平台写法
手动写 ANSI 容易出错,推荐轻量库自动处理:
-
colorama:初始化后让 Windows 也支持 ANSI,Jupyter 中虽非必需,但可统一逻辑
!pip install coloramafrom colorama import init; init() # 可选,Jupyter 中常可省略print("\x1b[36m青色\x1b[0m") -
rich:更现代,支持样式、表格、进度条,且在 Jupyter 中自动适配
!pip install richfrom rich.console import Consolec = Console()c.print("[bold red]错误[/],[green]成功[/]")
避免常见陷阱
有些情况会让颜色“消失”,其实是预期行为:
立即学习“Python免费学习笔记(深入)”;
- 使用
logging模块默认不走 stdout,ANSI 可能被过滤 → 改用rich.logging或自定义 handler - 在函数中只写
return "\033[31mxxx\033[0m"而不 print → 字符串本身含转义符,但没触发渲染;需print(...)或display(Markup(...)) - Jupyter 输出被
%%capture魔法命令捕获 → 颜色代码仍在字符串里,但不渲染;解除 capture 或显式 print 即可
进阶:动态着色 + 条件高亮
结合数据逻辑做条件变色,例如日志级别标记:
def log(level, msg):
colors = {"INFO": "\033[32m", "WARNING": "\033[33m", "ERROR": "\033[31m"}
reset = "\033[0m"
color = colors.get(level, "")
print(f"{color}[{level}]{reset} {msg}")
log("ERROR", "连接超时") # 显示为红色
这种模式清晰、轻量,适合调试和状态反馈,无需引入大依赖。










