日志功能

【背景】需求创建2个日志文件

【知识点】

logging.getLogger() 方法默认会返回一个以给定名称为标识的日志记录器(如果没有提供名称,则返回一个根日志记录器)

import logging
import cm  # 确保 cm 模块已经被正确导入,并且有一个 log_file 函数

class Log:
    def __init__(self, flag):
        # 为每个实例创建一个唯一的日志记录器名称
        logger_name = f"Log_{flag}"
        self.logger = logging.getLogger(logger_name)
        if not self.logger.handlers:
            self.logger.setLevel(logging.DEBUG)

            # 创建一个处理器写入文件
            fh = logging.FileHandler(cm.log_file(flag), encoding='utf-8')
            fh.setLevel(logging.INFO)

            # 创建一个处理器输出到控制台
            ch = logging.StreamHandler()
            ch.setLevel(logging.INFO)

            # 定义输出的格式
            formatter = logging.Formatter('%(levelname)s\t%(asctime)s\t[%(filename)s:%(lineno)d]\t%(message)s')
            fh.setFormatter(formatter)
            ch.setFormatter(formatter)

            # 将处理器添加到日志记录器
            self.logger.addHandler(fh)
            self.logger.addHandler(ch)

# 现在可以创建两个独立的日志记录器实例
flak_log = Log("flak").logger
log = Log("file").logger

# 使用日志记录器
flak_log.info("This is a flak log message.")
log.info("This is a file log message.")

 

posted on 2024-12-04 14:47  张凌赫_帅  阅读(23)  评论(0)    收藏  举报

导航