可通过五种方法使print()默认输出到stderr:一、覆盖内置print函数;二、用functools.partial创建print_err;三、重定向sys.stdout=sys.stderr;四、用contextlib.redirect_stdout临时重定向;五、封装模块级配置函数。

如果您希望 Python 中的 print() 函数默认将输出发送到标准错误流(stderr)而非标准输出流(stdout),则需修改其默认的 file 参数行为。以下是实现该目标的多种方法:
一、重定向全局 print() 的默认 file 参数
通过覆盖内置的 print 函数,可使其在每次调用时自动使用 sys.stderr 作为输出目标。此方法影响当前作用域内所有未显式指定 file 的 print() 调用。
1、导入 sys 模块和 builtins 模块。
2、定义一个新函数,内部调用原始 print 并强制设置 file=sys.stderr。
立即学习“Python免费学习笔记(深入)”;
3、使用 builtins.print = 新函数 替换内置函数。
二、使用 functools.partial 创建自定义 print 函数
利用 functools.partial 可预先绑定 print 的 file 参数为 sys.stderr,生成一个新函数。该方式不修改内置函数,仅在局部或模块级启用。
1、导入 functools 和 sys 模块。
2、执行 print_err = functools.partial(print, file=sys.stderr)。
3、后续调用 print_err("message") 即输出至 stderr。
三、设置环境变量并重写 sys.stdout
通过将 sys.stdout 重定向至 sys.stderr 的文件对象,可使所有依赖 sys.stdout 的输出(包括未指定 file 的 print())均流向 stderr。此操作影响整个解释器会话的标准输出通道。
1、导入 sys 模块。
2、执行 sys.stdout = sys.stderr。
3、此后所有未指定 file 的 print() 调用将写入 stderr。
四、在脚本入口处使用上下文管理器临时重定向
借助 contextlib.redirect_stdout,可在特定代码块中临时将 print() 输出重定向至 sys.stderr,退出块后自动恢复原 stdout。适用于局部、临时性需求。
1、导入 contextlib 和 sys 模块。
2、使用 with contextlib.redirect_stdout(sys.stderr): 开始代码块。
3、在缩进区域内调用 print(),其输出将进入 stderr。
五、封装为可复用的模块级配置函数
定义一个初始化函数,在模块加载时一次性配置所有后续 print() 行为。该函数结合了函数替换与属性保存,确保原始 print 仍可通过别名调用。
1、导入 builtins 和 sys 模块。
2、保存原始 print 为 builtins._original_print。
3、定义新 print 函数,调用 _original_print(..., file=sys.stderr)。
4、执行 builtins.print = 新函数。










