python打印日志logbook

python打印日志logbook1 自定义输入日志格式 log pyimportosim StreamHandle FileHandler TimedRotatin moreimportCo 日志类型自定义 deflog type record handler log date level

1. 自定义输入日志格式

  • log.py
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. 测试

  • test.py
 import os from log import run_log as logger if __name__ == "__main__": logger.info("这是测试日志...") logger.error("这是测试错误日志...") 

运行结果:

在这里插入图片描述
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/224435.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月17日 上午11:57
下一篇 2026年3月17日 上午11:57


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号