2020-10-07

    科技2024-07-24  12

    端到端中的问题记录:

    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可能会有延时,在服务器上训练的话,查看提交任务指定的输出文件也可以。 详细参照这篇文章

    Processed: 0.012, SQL: 8