如何让 print 默认输出到 stderr 而不是 stdout

print()默认输出到sys.stdout,可通过file参数指定sys.stderr;推荐用perr()封装函数实现语义清晰、安全可控的错误输出。

Python 的 print() 函数默认输出到 sys.stdout,但可以通过设置 file 参数直接指定输出目标为 sys.stderr

方法一:每次调用时显式指定 file=sys.stderr

这是最直接、最明确的方式,适合偶尔需要错误输出的场景:

import sys
print("这是一个错误信息", file=sys.stderr)
  • 不会影响其他 print 调用,安全可控
  • 适合调试、日志提示、CLI 工具中的错误消息
  • 注意:字符串内容不会自动加换行以外的格式,和 stdout 行为一致

方法二:重定义 print 函数(全局生效)

如果项目中大量需要将 print 默认导向 stderr,可以重新绑定内置 print:

import sys
print = lambda *args, **kwargs: __builtins__['print'](*args, file=sys.stderr, **kwargs)
# 后续所有 print 都会输出到 stderr
print("这条也走 stderr")
  • 需在程序早期执行,避免被其他模块提前使用原 print
  • 可能影响依赖 stdout 的第三方库(如某些进度条、颜色库),慎用于大型项目
  • 若需恢复,可保存原始 print:original_print = __builtins__['print']

方法三:封装一个 perr() 辅助函数(推荐)

兼顾清晰性与可维护性,不污染全局命名空间:

import sys
def perr(*args, **kwargs):
    kwargs.setdefault('file', sys.stderr)
    print(*args, **kwargs)

perr("警告:配置文件未找到") perr("详情", "见日志", sep=" | ")

  • 语义明确(perr 即 “print to stderr”),团队协作更易理解
  • 保留 print 的全部功能(sep、end、flush 等)
  • 可轻松扩展,比如自动添加前缀 [ERROR] 或时间戳

补充说明:重定向

整个 stdout 不等于改 print 默认行为

sys.stdout = sys.stderr 这类操作会影响所有写入 stdout 的行为(包括第三方库、input 提示、甚至某些 C 扩展),极易引发不可预期问题,不建议用于此目的。