ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

通过file.write()填充文件时,python-tail -f在外壳中似乎不起作用

2019-11-05 15:07:40  阅读:163  来源: 互联网

标签:file-io python


问候大家,

我试图守护当前在前台运行的python脚本.但是,我仍然需要能够看到其当前转储到stdout的输出.

因此,我正在使用以下代码,它们在/ tmp中生成一个唯一的文件名,然后将sys.stdout分配给该新文件.然后,所有对“打印”的后续调用都将重定向到该日志文件.

import uuid
outfile = open('/tmp/outfile-' + str(uuid.uuid4()), 'w')
outfile.write("Log file for daemon script...\n")
sys.stdout=outfile

# Rest of script uses print statements to dump information into the /tmp file
.
.
.

我面临的问题是,当我尾巴-f在/ tmp中创建的文件时,看不到任何输出.但是,一旦我终止了守护进程,在/ tmp日志文件中就可以看到输出,因为python清除了文件数据.

我想实时监视/ tmp日志文件,因此,如果能够以某种方式使输出实时可见,那就太好了.

我尝试过的一种解决方案是尝试使用未经处理的IO,但这也无济于事.

任何帮助将不胜感激!

谢谢并恭祝安康,
Warpcore

解决方法:

尝试使用无缓冲的I / O.问题几乎可以肯定是您的输出已缓冲.

像这样打开文件应该可以:

outfile = open(name, 'w', 0)

标签:file-io,python
来源: https://codeday.me/bug/20191105/1995816.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有