栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

Python color logging

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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('33[0;36m%s33[0m' % msg)  # 绿色
            elif record.levelno == 20:
                print('33[0;32m%s33[0m' % msg)  # 青蓝色
            elif record.levelno == 30:
                print('33[0;34m%s33[0m' % msg)  # 蓝色
            elif record.levelno == 40:
                print('33[0;35m%s33[0m' % msg)  # 紫红色
            elif record.levelno == 50:
                print('33[0;31m%s33[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)

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/876198.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号