Python日志无延迟实时写入的示例
我在用python生成日志时,发现无论怎么flush(),文件内容总是不能实时写入,导致程序意外中断时一无所获。
以下是查到的解决方案(亲测可行):
open函数中有一个bufferin的参数,默认是-1,如果设置为0是,就是无缓冲模式。
但是用二进制模式打开这个文件,并且把要写入的信息转换byte-like如下。
withopen("test.txt",'wb',buffering=0)asf:
#wb是写模式加二进制模式
f.write(b"hello!")在字符串前加b,转换成二进制
如果没用二进制打开文件会提示ValueEorror:
没把字符串转成二进制会提示:TypeError:abytes-likeobjectisrequired,not‘str'
测试:
classLogger(object):
def__init__(self,log_path="default.log"):
self.terminal=sys.stdout
#self.log=open(log_path,"w+")
self.log=open(log_path,"wb",buffering=0)
defprint(self,message):
self.terminal.write(message+"\n")
self.log.write(message.encode('utf-8')+b"\n")
defflush(self):
self.terminal.flush()
self.log.flush()
defclose(self):
self.log.close()
报错1:TypeError:can'tconcatstrtobytes
报错2:write需要str对象,无法写入bytes对象(大意)
这是因为:
(1)log.write需要写入bytes对象,这里没问题。但是encode返回的是bytes型的数据,不可以和str相加,需要将‘\n'前加b。
(2)terminal.write函数参数需要为str类型,转化为str。
改为:
defprint(self,message):
self.terminal.write(message+"\n")
self.log.write(message.encode('utf-8')+b"\n")
运行成功!
以上这篇Python日志无延迟实时写入的示例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。
热门推荐
10 祝女儿简短祝福语大全
11 大学新年祝福语简短创意
12 元旦适合的祝福语简短
13 朋友出远门祝福语简短
14 初六简短的祝福语
15 祝男孩生日祝福语简短
16 同事调离的祝福语简短
17 拜年红包的祝福语简短
18 妈妈生日祝福语简短励志