为了账号安全,请及时绑定邮箱和手机立即绑定

Python:将各个输出部分重定向到单独的变量

Python:将各个输出部分重定向到单独的变量

一只萌萌小番薯 2023-10-31 21:17:38
我正在尝试创建一种机制将输出重定向print到多个变量。以下代码模拟了我正在寻找的内容:-import sysimport ioclass MultiOut(object):    def __init__(self, stream_out):        self.terminal = sys.stdout        self.output = stream_out    def write(self, message):        self.terminal.write(message)        self.output.write(message)    def flush(self):        self.terminal.flush()        self.output.flush()vals = {'a1': io.StringIO(), 'a2': io.StringIO(), 'a3': io.StringIO()}for i,val in enumerate(vals):    sys.stdout = MultiOut(vals[val])    [print(x**i, end=' ') for x in range(11)]    print("\n")with open('temp.txt', 'w') as f:    for x in vals:        f.write(f"{x} :-\n")        f.write(vals[x].getvalue())        f.write(f"{'='*50}\n")文件输出(tmp.txt):-a1 :-1 1 1 1 1 1 1 1 1 1 1 0 1 2 3 4 5 6 7 8 9 10 0 1 4 9 16 25 36 49 64 81 100 ==================================================a2 :-0 1 2 3 4 5 6 7 8 9 10 0 1 4 9 16 25 36 49 64 81 100 ==================================================a3 :-0 1 4 9 16 25 36 49 64 81 100 ==================================================我在这里想做的是将输出的各个“部分”重定向到不同的变量vals - a1, a2, a3并将所有输出转储到终端。奇怪的是,每个连续变量都包含从该点开始直到结束的数据。有没有办法避免这个问题并将每个部分保存在不同的变量中?
查看完整描述

1 回答

?
慕田峪7331174

TA贡献1828条经验 获得超13个赞

问题是您正在用您的对象替换 sys.stdout :

sys.stdout = MultiOut(vals[val])

在你的对象初始化中,你将 sys.stdout 设置为对象属性

self.terminal = sys.stdout

在第二次迭代时,执行此语句时

self.terminal = sys.stdout

sys.stdout 是第一次迭代的替换,其中包括第一个MultiOut对象。

我希望这是有道理的。


我会使用日志记录模块来实现您想要的,而不是修改标准输出。


查看完整回答
反对 回复 2023-10-31
  • 1 回答
  • 0 关注
  • 58 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信