日志功能

【背景】需求创建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   张凌赫_帅  阅读(7)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示