当我们在服务器上跑python程序时,很多人会倾向于用python脚本的方式而不是用jupyter。那为了避免将结果直接输出在屏幕上以及方便我们查看输出信息,我们往往会选择将python程序的结果输出重定向到某个我们指定的日志文件(如果你还不太了解什么是重定向的话,可以看Linux中>,>>,>&,&>,&,&&,|,||,2>&1到底是什么?)。但如果直接重定向的话,你会发现程序的输出结果并不能即时地输出到日志文件中,非常不方便查看当前的运算进度。下面我们将介绍如何解决延迟输出的问题。
先给个例子:
[zhxia@core ~]python test.py &>test.log
这条命令的意思就是说: 运行test.py脚本,且将运行过程中本来要输出到屏幕/控制台的内容(如脚本里面的print语句、报错信息等)输出到test.log日志文件中去。
但这样直接输出重定向会存在延迟。主要是由于在python中,输出重定向的内容会先暂存在缓冲区中,当它遇到了换行符“\n”或者缓存区的数据积累到一定量的时候,才会将输出重定向的内容写入到指定的日志文件中去。如何解决这个问题?下面给出3种解决办法。
如何解决这个问题?下面给出3种解决办法。
对于上面那个例子,可以用下面的代码即时输出重定向的内容:
[zhxia@core ~]python -u test.py &>test.log
正常print()
函数中默认flush=False
,这样的话print()
函数会先把内容放在缓存中,并不一定能即时地刷新到屏幕、控制台。而令flush=True
,会在print()
函数结束后立即将内容显示到屏幕、控制台上,清空缓存。如
print('Hello World!', flush=True)
这个语句与上面令flush=True
原理类似,都是清空缓存,将内容输出出来。
sys.stdout.flush()
其实,我们也可以在服务器上用jupyter,具体可以看:如何在服务器上用jupyter。