【问题标题】:Make ipython notebook print in real time让 ipython notebook 实时打印
【发布时间】:2015-06-28 14:40:14
【问题描述】:

Ipython Notebook 似乎并没有实时打印结果,而是似乎以某种方式进行缓冲,然后批量输出打印结果。处理打印命令后,如何让 ipython 打印我的结果?

示例代码:

import time


def printer():
    for i in range(100):
        time.sleep(5)
        print i

假设上面的代码在一个被导入的文件中。我怎么能做到,当我调用打印机函数时,它每 5 秒打印一个数字,而不是最后的所有数字?

请注意,我无法编辑函数printer(),因为我是从某个外部模块获取的。我希望以某种方式更改 ipython 笔记本的配置,使其不使用缓冲区。因此,我也不希望使用 sys.stdout.flush(),我想根据问题实时执行,我不希望任何缓冲区开始。

我还尝试使用以下命令加载 ipython 笔记本:

ipython notebook --cache-size=0

但这似乎也不起作用。

【问题讨论】:

  • 谢谢。我的问题略有不同。我不想更改功能打印机(),因为我通过导入一个我不想更改的模块得到它。我只是想改变 ipython 的行为。因此,上述问题中提出的解决方案对我不起作用,因为我无法将 sys.stdout.flush() 添加到函数中。我想要的是 ipython 笔记本中没有缓冲区。它会自动输出所有内容。
  • 你可以修改打印机功能。
  • 可能,但应该有办法解除 ipython notebook stdout no 的缓冲?
  • 添加需求可以找到some answers here
  • 谢谢,但我真的找不到任何有用的东西。

标签: python buffer ipython-notebook


【解决方案1】:

另外,还可以使用回车符:

from time import sleep
for i in range(10):
    print(i, end='\r')
    sleep(1)

或者,如果您使用的是 Jupyter Notebooks:

from IPython.display import clear_output
from time import sleep
for i in range(10):
    print(i)
    sleep(1)
    clear_output(wait=True) 

【讨论】:

    【解决方案2】:

    试试这个:

    from IPython.display import display, clear_output
    
    display("Hello World") # print string
    display(df) # print object such as dataframe
    
    clear_output(wait=True) # use this if need to clear the output before display, good for dynamic updates
    

    【讨论】:

      【解决方案3】:

      从 Python 3.3 开始,print() 有一个 additional flush 参数,可用于强制刷新:

      for i in range(10):
          print(i, flush=True)
          time.sleep(1)  
      

      【讨论】:

        【解决方案4】:

        这只是one of the answersCarsten 提出的问题,在评论中结合了diedthreetimes 建议的__getattr__ 委托:

        import sys
        oldsysstdout = sys.stdout
        class flushfile():
            def __init__(self, f):
                self.f = f
            def __getattr__(self,name): 
                return object.__getattribute__(self.f, name)
            def write(self, x):
                self.f.write(x)
                self.f.flush()
            def flush(self):
                self.f.flush()
        sys.stdout = flushfile(sys.stdout)
        

        在原始答案中,__getattr__ 方法未实现。没有它,它就会失败。该问题的答案的其他变体在笔记本中也失败了。

        在笔记本中,sys.stdoutIPython.kernel.zmq.iostream.OutStream 的一个实例,并且具有许多通常的sys.stdout 中不存在的方法和属性。委派__getattr__ 允许flushfile 伪装成...zmq.iostream.OutStream 鸭子。

        这适用于使用 ipython 3.1.0 运行的 python 2.7 笔记本

        【讨论】:

        • 这是一个很好的解决方法,但谢谢!我会试试的。
        • 有效!! :) 谢谢!我将在 2 天内分配赏金。
        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2015-03-04
        • 2014-02-14
        • 2014-08-17
        • 2012-12-15
        • 1970-01-01
        • 1970-01-01
        • 2015-10-24
        相关资源
        最近更新 更多