python程序输出无内容的解决方式

 更新时间:2020年04月09日 11:39:25   作者:贾己人  
这篇文章主要介绍了python程序输出无内容的解决方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

问题缘由

某项目中使用python脚本方式将日志文件中的数据持续的转换格式输出到另一文件中以供其他日志分析应用使用。但是当后台运行采取重定向方式输出到某一文件时,发现并没有内容输出,命令如下:

python xxx.py > xxx.log &

测试发现,当前台直接输出到终端时正常,使用后台运行重定向的方式输出到文件中时无法输出。

解决办法

发现是在程序运行时,输出有缓存,只有当程序运行结束或者缓冲区满后才会输出。因为程序是一致在运行的所以不可能等待程序结束在输出。并且要求是有实时性的所以等缓冲区满输出的方式也不可取。

所以采用在python运行时加上-u参数,如:

python -u xxx.py > xxx.log &

-u参数的意义是不使用缓冲的方式输入输出

详细如下:

Force stdin, stdout and stderr to be totally unbuffered. On systems where it matters, also put stdin, stdout and stderr in binary mode. Note that there is internal buffering in xreadlines(), readlines() and file-object iterators (“for line in sys.stdin”) which is not influenced by this option. To work around this, you will want to use “sys.stdin.readline()” inside a “while 1:” loop.

补充知识:python中运行代码时没有报错但是也没有输出而且还有exit code 0的结束标志

如下所示:

f=open("passwd.txt",'r')
print (f.read(4))
f.close()

这是想要执行的代码

passwd.txt中的内容

ntp:x:38:38::/etc/ntp:/sbin/nologin
apache:x:48:48:Apache:/var/www:/sbin/nologin
saslauth:x:498:76:Saslauthd user:/var/empty/saslauth:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
gdm:x:42:42::/var/lib/gdm:/sbin/nologin
pulse:x:497:496:PulseAudio System Daemon:/var/run/pulse:/sbin/nologin

但是输出的结果是

Process finished with exit code 0

后来排查发现原来是解释器的问题

我之前使用的解释器是pycharm提供的虚拟解释器

#####如何查看解释器

点file–>new projects

如果选择的是2就是使用了pycharm提供的虚拟解释器,又因为passwd.txt文件不是在虚拟环境中的所以就没有输出。

点击3然后选择你已经下载好的解释器即可。

以上这篇python程序输出无内容的解决方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Python 多模式字符串搜索 Aho-Corasick详解

    Python 多模式字符串搜索 Aho-Corasick详解

    Aho-Corasick 算法是一种用于精确或近似多模式字符串搜索的高效算法,本文给大家介绍Python 多模式字符串搜索 Aho-Corasick的相关知识,感兴趣的朋友跟随小编一起看看吧
    2025-01-01
  • python opencv 读取本地视频文件 修改ffmpeg的方法

    python opencv 读取本地视频文件 修改ffmpeg的方法

    今天小编就为大家分享一篇python opencv 读取本地视频文件 修改ffmpeg的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-01-01
  • Python使用PIL库将PNG图片转换为ICO图标的示例代码

    Python使用PIL库将PNG图片转换为ICO图标的示例代码

    在软件开发和网站设计中,ICO图标是一种常用的图像格式,特别适用于应用程序图标、网页收藏夹图标等场景,本文将介绍如何使用Python的PIL库将PNG图片转换为ICO格式的图标文件,需要的朋友可以参考下
    2025-03-03
  • 详解如何利用Python代码删除Word文档空白行

    详解如何利用Python代码删除Word文档空白行

    Word文档内容的整洁性与易读性是体现文档水平的关键因素之一,许多错误或不合理的内容,如多余的空白行,Python为批量删除Word文档空白行以及对这一过程的自动化处理提供了强有力的支持,本文将介绍如何利用Python自动化删除Word文档中的空白行,需要的朋友可以参考下
    2024-05-05
  • Python中的闭包与装饰器的用法详解

    Python中的闭包与装饰器的用法详解

    这篇文章主要介绍了Python中的闭包与装饰器的用法详解,装饰器本质上是一个Python函数,它可以让其他函数在不需要做任何代码变动的前提下增加额外功能,装饰器的返回值也是一个函数对象,需要的朋友可以参考下
    2023-07-07
  • python学习教程之使用py2exe打包

    python学习教程之使用py2exe打包

    py2exe是一个将python脚本转换成windows上的可独立执行的可执行程序(*.exe)的工具,下面这篇文章主要给大家介绍了关于python学习教程之使用py2exe打包的相关资料,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧。
    2017-09-09
  • python反转字符串的七种解法总结

    python反转字符串的七种解法总结

    这篇文章主要介绍了反转字符串的多种方法,包括双指针、栈结构、range函数、reversed函数、切片、列表推导和reverse()函数,每种方法都有其特点和适用场景,需要的朋友可以参考下
    2025-01-01
  • python制作一个简单的gui 数据库查询界面

    python制作一个简单的gui 数据库查询界面

    这篇文章主要介绍了python制作一个简单的gui 数据库查询界面,帮助大家更好的理解和学习python tkinter的使用,感兴趣的朋友可以了解下
    2020-11-11
  • 基于python绘制科赫雪花

    基于python绘制科赫雪花

    这篇文章主要为大家详细介绍了基于python绘制科赫雪花,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-06-06
  • python教程之用py2exe将PY文件转成EXE文件

    python教程之用py2exe将PY文件转成EXE文件

    py2exe是一个将python脚本转换成windows上的可独立执行的可执行程序(*.exe)的工具,这样,你就可以不用装python而在windows系统上运行这个可执行程序。
    2014-06-06

最新评论