向控制台写入回车符时,是否删除整行?

2022-02-23 00:00:00 python pycharm console carriage-return

问题描述

我有一个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 ('===')

我的运行如下所示:

  1. xxx已打印
    [1秒后]
  2. ZZ已打印
    [1秒后]
  3. 该行已删除
    [1秒后]
  4. ===打印,程序终止

运行此脚本时,调试控制台和运行控制台中都会发生这种情况。


解决方案

答案实际上就在您的帖子中。如您所说,回车符将删除整行。要避免此问题,请仅在打印新行时打印回车符,如下所示:

打印每行,并在开头使用回车符,而不使用默认值end=' '。我不需要冲水,虽然我没有做太多测试。

print('xxx', end='')
# sys.stdout.flush()
time.sleep(1)

继续这样.

print('ZZ', end='')
time.sleep(1)

print('yyy', end='')
time.sleep(1)

若要保留上次打印输出,请保留默认结尾。

print('===')

相关文章