向控制台写入回车符时,是否删除整行?
问题描述
我有一个Python程序,它广泛使用换行符来产生更新控制台行(特别是进度条)的效果。在尝试调试PyCharm中的代码时,我看到进度条只有在调试完成后才会打印出来。
进一步检查后发现,当打印回车符(
)时,整行都会被删除。因为库本身写入形式为({line}
)的字符串,所以我总是得到一个空行。
示例代码:
import sys
sys.stdout.write('xxx')
sys.stdout.flush()
time.sleep(1)
sys.stdout.write('ZZ')
sys.stdout.flush()
time.sleep(1)
sys.stdout.write('yyy')
sys.stdout.flush()
time.sleep(1)
print ('===')
我的运行如下所示:
xxx
已打印
[1秒后]ZZ
已打印
[1秒后]- 该行已删除
[1秒后] ===
打印,程序终止
运行此脚本时,调试控制台和运行控制台中都会发生这种情况。
解决方案
答案实际上就在您的帖子中。如您所说,回车符将删除整行。要避免此问题,请仅在打印新行时打印回车符,如下所示:
打印每行,并在开头使用回车符,而不使用默认值end='
'
。我不需要冲水,虽然我没有做太多测试。
print('xxx', end='')
# sys.stdout.flush()
time.sleep(1)
继续这样.
print('ZZ', end='')
time.sleep(1)
print('yyy', end='')
time.sleep(1)
若要保留上次打印输出,请保留默认结尾。
print('===')
相关文章