端到端中的问题记录:
2020.10.7
sys.stdout的使用
sys.stdout的介绍
sys.stdout = io.TextIOWrapper(sys.stdout.buffer,encoding=‘utf8’)
目的是为了改变Print的编码输出,解码print输出中文是乱码的问题。
此行代码的详细介绍
# sys.stdout.write("\r# Process: %0.2f %%" % (float(n+1) / float(len(j)) * 100))
print("\r# Process: %0.2f %%" % (float(n+1) / float(len(j)) * 100), end='')
自定义实现进度条,end=""表示本次输出后与下次输出以什么字符为分割,\r表示光标回到行首,覆盖上一次的输入,这样就可以实现进度条的功能。end=’\r’的功能和这个相同.但是end=’\r不会留下痕迹。在Linux下可以试一下,在windows下不知道。
对于sys.stdout.flush():
作用:当我们需要打印一些字符时,并不是立刻就打印,而是先将需要打印的字符放入缓冲区,在缓冲区刷新时打印,当缓冲区未满,或者程序运行未结束时,可使用sys.stdout.flush()强制刷新缓冲区,立刻进行打印;
在windows下可以忽略,在linux下当遇到\n,或者缓存区满了以后才会输出。在上面的自定义进度条的例子中,由于有\r,所以不需要sys.stdout.flush().这个时候sys.stdout.flush()的作用应该是清空缓存,使输出更流畅,不太确定。
实时输出训练过程中的信息的话,python的logging模块非常方便,输出到自定义文件中,用wirte可能会有延时,在服务器上训练的话,查看提交任务指定的输出文件也可以。
详细参照这篇文章