【Python】Python日志无延迟实时写入

我在用python生成日志时,发现无论怎么flush(),文件内容总是不能实时写入,导致程序意外中断时一无所获。

以下是查到的解决方案(亲测可行):

open 函数中有一个bufferin的参数,默认是-1,如果设置为0是,就是无缓冲模式。 
但是用二进制模式打开这个文件,并且把要写入的信息转换byte -like如下。

with open("test.txt",'wb',buffering=0) as f:
#wb是写模式加二进制模式
    f.write(b"hello!")在字符串前加b,转换成二进制

如果没用二进制打开文件会提示ValueEorror:

没把字符串转成二进制会提示:TypeError: a bytes-like object is required, not ‘str’

写一个类:

class Logger(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)

    def print(self, message):
        self.terminal.write(str(message) + "\n")
        self.log.write(str(message).encode('utf-8') + b"\n")

    def flush(self):
        self.terminal.flush()
        self.log.flush()

    def close(self):
        self.log.close()

然后在正文里调用类:

log = Logger("data.log")
log.print('start!')

这样log.print()既能在屏幕打印,也能无延迟写入日志了!


报错1:TypeError: can't concat str to bytes

报错2:write需要str对象,无法写入bytes对象(大意)

这是因为:

(1)log.write需要写入bytes对象。因此encode返回的是bytes型的数据,不可以和str相加,需要将‘\n’前加b。

(2)terminal.write函数参数需要为str类型,转化为str。

 

Python将字符串转换为字节的两种方法

s = '北京'

a = bytes(s,'utf-8')
# ==》 得出的 a 的结果就是对应的字节

s.encode('utf-8')
# ==> 该命令将字符串转换为字节形式

 

展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 编程工作室 设计师: CSDN官方博客
应支付0元
点击重新获取
扫码支付

支付成功即可阅读