解决python print延迟问题

最近写了几个python脚本,在用print输出的时候,都有一个很讨厌的问题,就是print的输出被延迟了,什么情况呢,类似这样

1 import os

2 print ‘first print  

3 os.system('./second-print.sh')

在second-print.sh中,也会有一些打印信息输出到控制台

正常情况下,first print要先于second print出现再控制台,但实际的情况却是相反的。

这是个小问题,却非常的烦人,今天终于不能忍受,google了一番,发现很多人都有同样的痛苦,痛苦的根源是python默认启用了stdout缓冲,解决的办法有两种

一种办法是每次print后,都调用stdout flush(),把缓冲区打印出来,这个办法比较麻烦,要重载stdout,不推荐。最简单的方法是用命令行参数-u启动python,禁用stdout缓冲

比如脚本是build-native.py,运行 python -u build-native.py就不会出现print延迟问题了

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值