2020-10-07

端到端中的问题记录:

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值