python打印日志logbook
原创
©著作权归作者所有:来自51CTO博客作者wx58f59a601fad5的原创作品,请联系作者获取转载授权,否则将追究法律责任
1. 自定义输入日志格式
import os
import sys
import logbook
from logbook import Logger,StreamHandler,FileHandler,TimedRotatingFileHandler
from logbook.more import ColorizedStderrHandler
# 日志类型 自定义
def log_type(record,handler):
log = "[{date}] [{level}] [{filename}] [{func_name}] [{lineno}] {msg}".format(
date = record.time, # 日志时间
level = record.level_name, # 日志等级
filename = os.path.split(record.filename)[-1], # 文件名
func_name = record.func_name, # 函数名
lineno = record.lineno, # 行号
msg = record.message # 日志内容
)
return log
# 日志存放路径
# 如果不存在,则创建日志目录
LOG_DIR = os.path.join("Log")
if not os.path.exists(LOG_DIR):
os.makedirs(LOG_DIR)
# 日志打印到屏幕
log_std = ColorizedStderrHandler(bubble=True)
log_std.formatter = log_type
# 日志打印到文件
log_file = TimedRotatingFileHandler(os.path.join(LOG_DIR, '%s.log' % 'log'),date_format='%Y-%m-%d', bubble=True, encoding='utf-8')
log_file.formatter = log_type
# 脚本日志
run_log = Logger("script_log")
def init_logger():
logbook.set_datetime_format("local") # 设置时区格式为本地
run_log.handlers = []
run_log.handlers.append(log_file)
run_log.handlers.append(log_std)
# 实例化,默认调用
init_logger()
2. 测试
import os
from log import run_log as logger
if __name__ == "__main__":
logger.info("这是测试日志...")
logger.error("这是测试错误日志...")
运行结果:
【参考】
官网地址: https://logbook.readthedocs.io/en/stable/