Python color logging

#!/tool/python/3.6.12/bin/python3

"""
@File: logger.py
@Author:
@Date: 
@Contact:
@Desc: define Log class
"""


import logging


class ColorHandler(logging.StreamHandler):
    """彩色日志,根据不同级别的日志显示不同颜色"""

    def emit(self, record):
        try:
            msg = self.format(record)
            if record.levelno == 10:
                print('\033[0;36m%s\033[0m' % msg)  # 绿色
            elif record.levelno == 20:
                print('\033[0;32m%s\033[0m' % msg)  # 青蓝色
            elif record.levelno == 30:
                print('\033[0;34m%s\033[0m' % msg)  # 蓝色
            elif record.levelno == 40:
                print('\033[0;35m%s\033[0m' % msg)  # 紫红色
            elif record.levelno == 50:
                print('\033[0;31m%s\033[0m' % msg)  # 血红色
        except (KeyboardInterrupt, SystemExit):
            raise
        except:
            self.handleError(record)


class Log:
    """
        logger = logging.getLogger("mainModule")
        self.logger = logging.getLogger("mainModule.sub.module")
    """
    level_dict = {"CRITICAL": 50,
                  "FATAL": 50,
                  "ERROR": 40,
                  "WARNING": 30,
                  "WARN": 30,
                  "INFO": 20,
                  "DEBUG": 10,
                  "NOTSET": 0}

    def __init__(self, level="INFO", name=""):
        self.level = self.level_dict[level]
        self.logger = logging.getLogger(name)
        self.logger.setLevel(self.level)
        self.formatter = logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s", "%Y-%m-%d %H:%M:%S")
        # self.console = logging.StreamHandler()
        self.console = ColorHandler()
        self.console.setLevel(self.level)
        # self.console.setFormatter(self.formatter)
        # self.console.setFormatter(logging.Formatter('%(asctime)s - %(message)s', "%Y-%m-%d %H:%M:%S"))
        self.console.setFormatter(logging.Formatter( "%(levelname)s: %(message)s"))
        self.logger.addHandler(self.console)

    def set_log_name(self, log_name):
        self.write_log = True
        self.handler = logging.FileHandler(log_name, mode='w')
        self.handler.setLevel(self.level)
        self.handler.setFormatter(self.formatter)
        self.logger.addHandler(self.handler)

    def clear_logger(self):
        if self.write_log:
            self.handler.close()
            self.logger.removeHandler(self.handler)
        self.console.close()
        self.logger.removeHandler(self.console)

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以通过给 `logging` 模块的输出添加颜色来更好地区分不同级别的日志。具体方法是创建一个自定义的 `Formatter` 类,并在其中添加 ANSI 转义序列来修改文本颜色。 以下是一个示例代码: ```python import logging class ColoredFormatter(logging.Formatter): """ 自定义日志格式,添加颜色 """ def format(self, record): if record.levelno == logging.DEBUG: # 绿色字体 color_start = '\033[32m' elif record.levelno == logging.INFO: # 默认字体颜色 color_start = '' elif record.levelno == logging.WARNING: # 黄色字体 color_start = '\033[33m' elif record.levelno == logging.ERROR: # 红色字体 color_start = '\033[31m' elif record.levelno == logging.CRITICAL: # 紫色字体 color_start = '\033[35m' else: color_start = '' color_end = '\033[0m' self._style._fmt = color_start + self._style._fmt + color_end return super().format(record) # 创建 logger logger = logging.getLogger('my_logger') logger.setLevel(logging.DEBUG) # 创建 StreamHandler,并添加到 logger 中 handler = logging.StreamHandler() handler.setLevel(logging.DEBUG) # 创建 Formatter,并添加到 handler 中 formatter = ColoredFormatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s') handler.setFormatter(formatter) # 添加 handler 到 logger 中 logger.addHandler(handler) # 输出不同级别的日志 logger.debug('This is a debug message') logger.info('This is an info message') logger.warning('This is a warning message') logger.error('This is an error message') logger.critical('This is a critical message') ``` 在这个例子中,我们创建了一个自定义的 `Formatter` 类 `ColoredFormatter`,并在其中根据不同的日志级别添加了不同的颜色。然后将这个 `Formatter` 添加到 `StreamHandler` 中,并将其添加到 logger 中,从而实现了对输出日志的颜色控制。 注意,为了保证每个日志输出的颜色都是正确的,我们每次都需要在 `format` 方法中重新设置 `_style._fmt`。如果不这么做,可能会出现某些日志输出颜色不正确的情况。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值