如何强制Python的print函数将缓冲输出刷新到屏幕?


另请参阅:如果目标是更改缓冲行为,则禁用输出缓冲。这个问题是关于在特定打印调用后显式刷新输出,即使输出仍在缓冲。

对于重复的闭包:如果初学者问了一个问题,试图在结尾处不使用换行符的情况下立即显示输出,请改用“当结尾处没有换行符时,为什么打印输出不立即显示在终端中?”?结束问题。目前的问题还不够好,因为提问者可能没有缓冲或冲洗的概念;另一个问题旨在首先解释这些概念,而这个问题是关于技术细节的。


当前回答

在Python 3中,您可以使用默认设置为flush=True来覆盖打印函数

def print(*objects, sep=' ', end='\n', file=sys.stdout, flush=True):
    __builtins__.print(*objects, sep=sep, end=end, file=file, flush=flush)

其他回答

此外,正如这篇博文中所建议的,可以在无缓冲模式下重新打开sys.stdout:

sys.stdout = os.fdopen(sys.stdout.fileno(), 'w', 0)

每个stdout.write和打印操作之后都会自动刷新。

在Python 3中,print可以采用可选的flush参数:

print("Hello, World!", flush=True)

在Python 2中,调用print后,请执行以下操作:

import sys
sys.stdout.flush()

默认情况下,打印到sys.stdout(有关文件对象的详细信息,请参阅文档)。

这是我的版本,它也提供了writeline()和fileno():

class FlushFile(object):
    def __init__(self, fd):
        self.fd = fd

    def write(self, x):
        ret = self.fd.write(x)
        self.fd.flush()
        return ret

    def writelines(self, lines):
        ret = self.writelines(lines)
        self.fd.flush()
        return ret

    def flush(self):
        return self.fd.flush

    def close(self):
        return self.fd.close()

    def fileno(self):
        return self.fd.fileno()

使用无缓冲区文件:

f = open('xyz.log', 'a', 0)

Or

sys.stdout = open('out.log', 'a', 0)

在Python 3中,您可以使用默认设置为flush=True来覆盖打印函数

def print(*objects, sep=' ', end='\n', file=sys.stdout, flush=True):
    __builtins__.print(*objects, sep=sep, end=end, file=file, flush=flush)