【问题标题】:Python: Redirect various output sections to separate variablesPython:将各种输出部分重定向到单独的变量
【发布时间】:2020-10-13 07:24:13
【问题描述】:

我正在尝试创建一种将print 输出重定向到多个变量的机制。以下代码模拟了我正在寻找的内容:-

import sys
import io

class 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 的不同变量,并将所有输出转储到终端。奇怪的是,每个连续变量都包含从该点开始到结束的数据。有没有办法避免这个问题并将每个部分保存在不同的变量中?

【问题讨论】:

    标签: python python-3.x stringio


    【解决方案1】:

    问题是您将 sys.stdout 替换为您的对象:

    sys.stdout = MultiOut(vals[val])
    

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

    self.terminal = sys.stdout
    

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

    self.terminal = sys.stdout
    

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

    我希望这是有道理的。


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

    【讨论】:

    • 我看到了这个问题。非常感谢!
    猜你喜欢
    • 2023-04-11
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2014-10-31
    • 2012-07-02
    • 2019-03-20
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多