Python日志:根据日志级别打印不同颜色的日志(runLog.py)

注意:

1:logging模块中
logger = logging.getLogger()
logger的handler的错误级别必须大于等于logger本身的错误级别, 
handler的错误级别设置才能生效,否则, logger的错误级别覆盖其handler的错误级别

1

# -*-coding:UTF-8-*-
import logging
import os
import time


class Logger(object):
        """
    终端打印不同颜色的日志,在pycharm中如果强行规定了日志的颜色, 这个方法不会起作用, 但是
    对于终端,这个方法是可以打印不同颜色的日志的。
    """ 

    logger = logging.getLogger("root")
    logger.setLevel(logging.DEBUG)

    tool_log_path = os.path.join(os.path.abspath(os.path.dirname(os.path.dirname(__file__))), "logs")
    if not os.path.exists(tool_log_path):
        os.makedirs(tool_log_path)
    tool_log_file = os.path.normpath(os.path.join(tool_log_path, "tool_log" + time.strftime("%Y%m%d", time.localtime())+ ".log"))
    # 创建一个handler,用于写入日志文件
    tool_log = logging.FileHandler(
        tool_log_file,
        encoding='utf-8')
    tool_log.set_name('tool_log')
    tool_log.setLevel(logging.INFO)

    # 控制台输出
    console = logging.StreamHandler()
    console.set_name('console')
    tool_log.setLevel(logging.DEBUG)


    # 定义handler的输出格式
    formatter = logging.Formatter('[%(asctime)s] - [%(levelname)s] - %(message)s')

    # handler添加format
    console.setFormatter(formatter)
    tool_log.setFormatter(formatter)

    # 给logger添加handler
    logger.addHandler(console)
    logger.addHandler(tool_log)

    @classmethod
    def add_handler(cls, logger_obj, handler_name, log_path, log_file_name):
        """
        增加一个写日志文件的handler, 用于自定义日志文件名

        :param logger_obj: logging.getLogger(name)对象
        :param handler_name: handler name
        :param log_path: 日志文件所在路径
        :param log_file_name: 日志文件名
        :return:
        """
        if not os.path.exists(log_path):
            logger_obj.error("路径不存在")
        f = open(os.path.normpath(os.path.join(log_path, log_file_name)), 'a')

        # 日志文件生成
        log_handler = logging.StreamHandler()
        log_handler.set_name(handler_name)

        # 更改流对象
        if not "stderr" in log_handler.stream.name:
            log_handler.stream.close()
        log_handler.stream = f

        # 为指定的logger添加名字为handler_name的handler
        log_handler.setLevel(logging.INFO)
        log_handler.setFormatter(cls.formatter)
        logger_obj.addHandler(log_handler)

    @classmethod
    def debug(cls, message, *args, **kwargs):
        """
        输出调试信息

        :param message: 调试信息
        :return:
        """
        cls.fontColor('\033[0;32m%s\033[0m')
        cls.logger.debug(message, *args, **kwargs)

    @classmethod
    def info(cls, message, *args, **kwargs):
        """
        输出程序运行详细信息

        :param message: 详细信息
        :return:
        """
        cls.fontColor('\033[0;34m%s\033[0m')
        cls.logger.info(message, *args, **kwargs)

    @classmethod
    def warning(cls, message, *args, **kwargs):
        """
        输出程序运行警告信息

        :param message: 警告信息
        :return:
        """
        cls.fontColor('\033[0;37m%s\033[0m')
        cls.logger.warning(message, *args, **kwargs)

    @classmethod
    def error(cls, message, *args, **kwargs):
        """
        输出程序运行错误信息

        :param message: 错误信息
        :return:
        """
        cls.fontColor('\033[0;31m%s\033[0m')
        cls.logger.error(message, *args, **kwargs)

    @classmethod
    def critical(cls, message, *args, **kwargs):
        """
        输出程序运行严重错误信息

        :param message: 错误信息
        :return:
        """
        cls.fontColor('\033[0;35m%s\033[0m')
        cls.logger.critical(message, *args, **kwargs)

    @classmethod
    def fontColor(cls, color):
        """
        更改控制台输出的日志颜色

        :param color: 颜色种类
        :return:
        """
        formatter = logging.Formatter(color % '[%(asctime)s] - [%(levelname)s] - %(message)s')
        cls.console.setFormatter(formatter)



if __name__ == "__main__":
    Logger.info("12345")
    Logger.debug("12345")
    Logger.warning("12345")
    Logger.error("12345")
    print(type(Logger.logger.handlers[1].stream))
    # 日志分流, 保存初始流
    Logger.logger.handlers[1].ssssstream = Logger.logger.handlers[1].stream
    # Loggers.get_test_log("/root/桌面/absd/logs", "test_log.log")
    f = open("/root/桌面/asdf/logs/test_log.log", 'w')
    # 日志分流
    Logger.logger.handlers[1].stream = f
    Logger.info("12345")
    Logger.debug("12345")
    Logger.warning("12345")
    Logger.error("12345")
    # 关闭流
    Logger.logger.handlers[1].stream.close()
    # 日志分流, 恢复初始流
    Logger.logger.handlers[1].stream = Logger.logger.handlers[1].ssssstream
    del Logger.logger.handlers[1].ssssstream
    Logger.info("12345")
    Logger.debug("12345")
    Logger.warning("12345")
    Logger.error("12345")


0

# -*-coding:UTF-8-*-
import logging
import os
import time


class logger(object):
    
    """
    终端打印不同颜色的日志,在pycharm中如果强行规定了日志的颜色, 这个方法不会起作用, 但是
    对于终端,这个方法是可以打印不同颜色的日志的。
    """ 

    #在这里定义StreamHandler,可以实现单例, 所有的logger()共用一个StreamHandler
    ch = logging.StreamHandler()
    def __init__(self):
        self.logger = logging.getLogger()
        if not self.logger.handlers:
            #如果self.logger没有handler, 就执行以下代码添加handler
            self.logger.setLevel(logging.DEBUG)
            from serviceProgram.utils.FileUtil import FileUtil
            rootPath = FileUtil.getProgrameRootPath()
            self.log_path = rootPath + '/logs'
            if not os.path.exists(self.log_path):
                os.makedirs(self.log_path)

            # 创建一个handler,用于写入日志文件
            fh = logging.FileHandler(self.log_path + '/runlog' + time.strftime("%Y%m%d", time.localtime()) + '.log', encoding='utf-8')
            # 设置写入文件的日志等级
            fh.setLevel(logging.DEBUG)

            # 定义handler的输出格式
            formatter = logging.Formatter('[%(asctime)s] - [%(levelname)s] - %(message)s')
            fh.setFormatter(formatter)

            # 给logger添加handler
            self.logger.addHandler(fh)

    def debug(self, message):
        self.fontColor('\033[0;32m%s\033[0m')
        self.logger.debug(message)

    def info(self, message):
        self.fontColor('\033[0;34m%s\033[0m')
        self.logger.info(message)

    def warning(self, message):
        self.fontColor('\033[0;37m%s\033[0m')
        self.logger.warning(message)

    def error(self, message):
        self.fontColor('\033[0;31m%s\033[0m')
        self.logger.error(message)

    def critical(self, message):
        self.fontColor('\033[0;35m%s\033[0m')
        self.logger.critical(message)

    def fontColor(self, color):
        #不同的日志输出不同的颜色
        formatter = logging.Formatter(color % '[%(asctime)s] - [%(levelname)s] - %(message)s')
        self.ch.setFormatter(formatter)
        self.logger.addHandler(self.ch)


if __name__ == "__main__":
    logger = logger()
    logger.info("12345")
    logger.debug("12345")
    logger.warning("12345")
    logger.error("12345")

其他

以下来自http://www.luyixian.cn/news_show_6646.aspx
实现过程:

      终端的字符颜色是用转义序列控制的,是文本模式下的系统显示功能,和具体的语言无关。

      转义序列是以ESC开头,即用\033来完成(ESC的ASCII码用十进制表示是27,用八进制表示就是033)。

 

书写格式:
     开头部分:\033[显示方式;前景色;背景色m + 结尾部分:\033[0m

     注意:开头部分的三个参数:显示方式,前景色,背景色是可选参数,可以只写其中的某一个;另外由于
    表示三个参数不同含义的数值都是唯一的没有重复的,所以三个参数的书写先后顺序没有固定要求,系统
    都能识别;但是,建议按照默认的格式规范书写。

     对于结尾部分,其实也可以省略,但是为了书写规范,建议\033[***开头,\033[0m结尾。

 

数值表示的参数含义:


常见开头格式:
\033[0m            默认字体正常显示,不高亮
\033[32;0m       红色字体正常显示
\033[1;32;40m  显示方式: 高亮    字体前景色:绿色  背景色:黑色
\033[0;31;46m  显示方式: 正常    字体前景色:红色  背景色:青色

 

实例:

  (1)print("\033[1;31;40m您输入的帐号或密码错误!\033[0m")  

  上方代码的输出格式为:字体高亮,红色前景,黄色背景      PS:前景色也就是字体的颜色
  

  (2)print("\033[0;31m%s\033[0m" % "输出红色字符")

  #上方代码的输出格式为:字体默认,红色前景

  

LOG_INFO='INFO'
LOG_ERROR='ERROR'
LOG_WARNING='WARNING'
LOG_NOTIFY='NOTIFY'
LOG_DEBUG='DEBUG'
LOG_USER='USER'

def info_log(value):
    if log_level > 3:
        print("\033[0;37;40m%s\033[0m"%value)

def error_log(value):
    if log_level != 0:
        print("\033[0;31;40m%s\033[0m"%value)

def warning_log(value):
    if log_level > 1:
        print("\033[0;33;40m%s\033[0m"%value)

def debug_log(value):
    if log_level > 5:
        print("\033[0;34;40m%s\033[0m"%value)

def notify_log(value):
    if log_level > 2:
        print("\033[0;36;40m%s\033[0m"%value)

def user_log(value):
    if log_level > 4:
        print("\033[0;32;40m%s\033[0m"%value)

def ZLOG(log_type,value):
    switcher={
        'INFO':info_log,
        'ERROR':error_log,
        'WARNING':warning_log,
        'DEBUG':debug_log,
        'NOTIFY':notify_log,
        'USER':user_log
    }
    return switcher[log_type](value)

test="hello world"
ZLOG(LOG_INFO,"output info log %s"%test)
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值