gpt4 book ai didi

python - 打印到 Python : redirect vs print's file argument vs write 中的文件

转载 作者:太空狗 更新时间:2023-10-29 22:10:05 34 4
gpt4 key购买 nike

我有一堆 print 调用需要写入文件而不是 stdout。 (我根本不需要 stdout。)

我正在考虑三种方法。其中任何一个有什么优势(包括性能)吗?

完全重定向,我看到了here :

import sys

saveout = sys.stdout
fsock = open('out.log', 'w')
sys.stdout = fsock

print(x)
# and many more print calls

# later if I ever need it:
# sys.stdout = saveout
# fsock.close()

在每个打印语句中重定向:

fsock = open('out.log', 'w')
print(x, file = fsock)
# and many more print calls

写函数:

fsock = open('out.log', 'w')
fsock.write(str(x))
# and many more write calls

最佳答案

我预计这些方法之间不会有任何持久的性能差异。

第一种方法的优点是,您所依赖的任何行为良好的代码(您导入的模块)都会自动选择您想要的重定向。

第二种方法没有优势。它只适用于调试或一次性代码……甚至不是一个好主意。您希望将输出决策整合到几个明确定义的位置,而不是在每次调用 print() 时分散在代码中。在 Python3 中,print() 是一个函数而不是语句。如果您愿意,这允许您重新定义它。因此,如果需要,您可以def print(*args)。如果您需要访问它,您也可以调用 __builtins__.print(),例如,在您自己的自定义 print() 的定义中。

第三种方法……以及所有输出都应该在您为此目的定义的特定函数和类方法中生成的原则……可能是最好的方法。

您应该尽可能将输出和格式与核心功能分开。通过将它们分开,您可以重复使用您的核心。 (例如,您可能从打算从文本/shell 控制台运行的东西开始,然后需要为其提供 Web UI、全屏(curses)前端或 GUI。您也可以构建完全不同的功能围绕它......在结果数据需要以其 native 形式(作为对象)返回而不是作为文本(输出)拉入并重新解析为新对象的情况下。

例如,我不止一次偶尔会写一些东西来执行一些复杂的查询和从各种来源收集数据并打印一份报告……说出差异……以后需要将其改编成表格它可以以某种形式(例如 YAML/JSON)吐出数据,这些数据可以被馈送到其他系统(例如,用于将一个数据源与另一个数据源进行协调。

如果从一开始就将主要操作与输出和格式化分开,那么这种调整相对容易。否则,它需要相当多的重构(有时相当于完全重写)。

关于python - 打印到 Python : redirect vs print's file argument vs write 中的文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4090997/

34 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com