前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >3招解决python程序输出重定向时的延迟问题

3招解决python程序输出重定向时的延迟问题

作者头像
自学气象人
发布2022-11-14 16:10:44
2.1K0
发布2022-11-14 16:10:44
举报
文章被收录于专栏:自学气象人

应用场景

当我们在服务器上跑python程序时,很多人会倾向于用python脚本的方式而不是用jupyter。那为了避免将结果直接输出在屏幕上以及方便我们查看输出信息,我们往往会选择将python程序的结果输出重定向到某个我们指定的日志文件(如果你还不太了解什么是重定向的话,可以看Linux中>,>>,>&,&>,&,&&,|,||,2>&1到底是什么?)。但如果直接重定向的话,你会发现程序的输出结果并不能即时地输出到日志文件中,非常不方便查看当前的运算进度。下面我们将介绍如何解决延迟输出的问题。

直接输出重定向存在延迟

先给个例子:

代码语言:javascript
复制
[zhxia@core ~]python test.py &>test.log 

这条命令的意思就是说: 运行test.py脚本,且将运行过程中本来要输出到屏幕/控制台的内容(如脚本里面的print语句、报错信息等)输出到test.log日志文件中去。

但这样直接输出重定向会存在延迟。主要是由于在python中,输出重定向的内容会先暂存在缓冲区中,当它遇到了换行符“\n”或者缓存区的数据积累到一定量的时候,才会将输出重定向的内容写入到指定的日志文件中去。如何解决这个问题?下面给出3种解决办法。

即时输出重定向的3种方法

如何解决这个问题?下面给出3种解决办法。

运行脚本加上-u参数(推荐)

对于上面那个例子,可以用下面的代码即时输出重定向的内容:

代码语言:javascript
复制
[zhxia@core ~]python -u test.py &>test.log 

在print函数中令flush=True

正常print()函数中默认flush=False,这样的话print()函数会先把内容放在缓存中,并不一定能即时地刷新到屏幕、控制台。而令flush=True,会在print()函数结束后立即将内容显示到屏幕、控制台上,清空缓存。如

代码语言:javascript
复制
print('Hello World!', flush=True)

在希望输出处加上sys.stdout.flush()语句

这个语句与上面令flush=True原理类似,都是清空缓存,将内容输出出来。

代码语言:javascript
复制
sys.stdout.flush()

其他

其实,我们也可以在服务器上用jupyter,具体可以看:如何在服务器上用jupyter。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-10-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 自学气象人 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 应用场景
    • 直接输出重定向存在延迟
      • 即时输出重定向的3种方法
        • 运行脚本加上-u参数(推荐)
        • 在print函数中令flush=True
        • 在希望输出处加上sys.stdout.flush()语句
        • 其他
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档