from sys import argv, stdout as cout
from time import sleep as sl
print("Rewinding.......",end = '') # If end is given output isn't flushed. But why?
cout.flush()
for i in range(0,20):
sl(0.2)
print(".",end='',flush = True) #No output is printed if flush wasn't specified as true.
print("Done") #Output is by default flushed here
When I specified end and sleep, I noticed that output wasn't flushed until next print where it was by default flushed.
Why does this happen? I had to manually flush the output.
解决方案
In fact this is the default behavior of the underlying stdio functions.
When the output is to console, the stream will be automatically flushed when a newline is encountered, but not other characters.
If the output is not a console, then even newline won't trigger a flush.
If you want to make sure about flush, you can tell the print() explicitly:
print("Rewinding.......",end = '',flush=True)
博客围绕Python输出刷新问题展开。代码中指定end和sleep时,输出未及时刷新,需手动调用flush。原因是底层stdio函数默认行为,输出到控制台时遇换行符才自动刷新,非控制台时换行也不触发。可通过print函数的flush参数确保刷新。
5645

被折叠的 条评论
为什么被折叠?



