问题
The following code is supposed to print from 1 to 10 with 1 second intervals in between, however it is waiting for 10 seconds before actually printing anything and then it prints it all at once. How can I unbuffer the output?
import sys
import time
for count in range(10) :
sys.stdout.write(str(count))
sys.stdout.flush()
time.sleep(1)
回答1:
Found the problem
import sys
import time
for count in range(10) :
sys.stdout.write("\b%s" % count)
sys.stdout.flush()
time.sleep(.1)
Don't know why python is weird like this but apparently it accepted this. Your code should've worked fine but I guess python just didn't like you.
回答2:
Python 2.7, 3.2, and 3.3 all don't allow keyword arguments in your write call. Is that the proper code? The print function of course allows the end keyword and shouldn't be confused with write. Write does not add a newline character.
Removing 'end' keyword argument and testing shows the code works fine.
来源:https://stackoverflow.com/questions/12755686/python-sys-stdout-flush-doesnt-work