缓冲区的刷新方式:
1.flush()刷新缓存区
2.缓冲区满时,自动刷新
3.文件关闭或者是程序结束自动刷新。
当我们打印一些字符时,并不是调用print函数后就立即打印的。一般会先将字符送到缓冲区,然后再打印。这就存在一个问题,如果你想等时间间隔的打印一些字符,但由于缓冲区没满,不会打印。就需要采取一些手段。如每次打印后强行刷新缓冲区。
for i in range(n):
print " * ",
sys.stdout.flush() #刷新缓冲区
time.sleep(1)
在使用tqdm时,就遇到这种问题:
明明是一个加载条,却打印出两个,影响美观。后发现是因为在加载条前有一句打印语句,可以看到tqdm先打印了一个加载条,但后面又来了个print,导致tqdm只能重新再打印一个加载条。因此强行刷新了缓冲区。
print(f'starting load trainset {cur_class} {n}')
sys.stdout.flush()
for i in tqdm(range(n)):