Python 3.8.0 奇怪的打印错误
Python 3.8.0 Weird printing bug
我在使用 Threads 和 Termios 时遇到一个非常奇怪的 print() 错误。我有一个重复的线程在打印一些东西时通过 Termios 捕获一个键。但它总是打印一个新行,它不是从该行的开头开始,而是从最后一行结束的地方开始。
这是我的代码:
def func1():
while True:
try:
var = int(inputChar())
except ValueError:
var = 0
Thread(target=func1).start()
while True:
print("stuff")
time.sleep(2)
这是我的 inputChar() 函数:
import sys, tty, termios
fd = sys.stdin.fileno()
old_settings = termios.tcgetattr(fd)
try:
tty.setraw(sys.stdin.fileno())
ch = sys.stdin.read(1)
finally:
termios.tcsetattr(fd, termios.TCSADRAIN, old_settings)
return ch
这是预期的输出:
stuff
stuff
stuff
stuff
stuff
这是输出:
stuff
stuff
stuff
stuff
stuff
我不知道为什么会这样,但您可以通过将打印命令替换为
来修复它
print("stuff\r")
或
sys.stdout.write("stuff\n\r")
末尾的 \r 称为墨盒 return。当 sys.stdout.write() 不是一个可行的选项时很有用
我在使用 Threads 和 Termios 时遇到一个非常奇怪的 print() 错误。我有一个重复的线程在打印一些东西时通过 Termios 捕获一个键。但它总是打印一个新行,它不是从该行的开头开始,而是从最后一行结束的地方开始。
这是我的代码:
def func1():
while True:
try:
var = int(inputChar())
except ValueError:
var = 0
Thread(target=func1).start()
while True:
print("stuff")
time.sleep(2)
这是我的 inputChar() 函数:
import sys, tty, termios
fd = sys.stdin.fileno()
old_settings = termios.tcgetattr(fd)
try:
tty.setraw(sys.stdin.fileno())
ch = sys.stdin.read(1)
finally:
termios.tcsetattr(fd, termios.TCSADRAIN, old_settings)
return ch
这是预期的输出:
stuff
stuff
stuff
stuff
stuff
这是输出:
stuff
stuff
stuff
stuff
stuff
我不知道为什么会这样,但您可以通过将打印命令替换为
来修复它print("stuff\r")
或
sys.stdout.write("stuff\n\r")
末尾的 \r 称为墨盒 return。当 sys.stdout.write() 不是一个可行的选项时很有用