码迷,mamicode.com
首页 > 其他好文 > 详细

colorlog的三个例子

时间:2018-09-02 17:09:03      阅读:251      评论:0      收藏:0      [点我收藏+]

标签:evel   日志收集   指定   fun   div   res   from   cname   五步   

例1:默认的log_colors

import logging
from logging.handlers import RotatingFileHandler
from colorlog import ColoredFormatter

#第一步:创建一个日志收集器logger
logger = logging.getLogger("autotest")

#第二步:修改日志的输出级别
logger.setLevel(logging.DEBUG)

#第三步:设置输出的日志内容格式
fmt = "%(log_color)s%(asctime)s  %(log_color)s%(filename)s  %(log_color)s%(funcName)s [line:%(log_color)s%(lineno)d] %(log_color)s%(levelname)s %(log_color)s%(message)s"
datefmt = %a, %d %b %Y %H:%M:%S

formatter = ColoredFormatter(fmt=fmt,
                       datefmt=datefmt,
                       reset=True,
                       secondary_log_colors={},
                       style=%
                       )

#设置输出渠道--输出到控制台
hd_1 = logging.StreamHandler()
#在handler上指定日志内容格式
hd_1.setFormatter(formatter)


#第五步:将headler添加到日志logger上
logger.addHandler(hd_1)

#第六步:调用输出方法
logger.debug("我是debug级别的日志")
logger.info("我是info级别的日志")
logger.warning("我是warning级别的日志")
logger.critical("我的critical级别的日志")
logger.error("我是error级别的日志输出")

默认的color_colors的值为:

技术分享图片

代码运行结果:

技术分享图片

例2:自定义log_colors

 

import logging
from logging.handlers import RotatingFileHandler
from colorlog import ColoredFormatter

#第一步:创建一个日志收集器logger
logger = logging.getLogger("autotest")

#第二步:修改日志的输出级别
logger.setLevel(logging.DEBUG)

#第三步:设置输出的日志内容格式
fmt = "%(log_color)s%(asctime)s  %(log_color)s%(filename)s  %(log_color)s%(funcName)s [line:%(log_color)s%(lineno)d] %(log_color)s%(levelname)s %(log_color)s%(message)s"
datefmt = %a, %d %b %Y %H:%M:%S

formatter = ColoredFormatter(fmt=fmt,
                       datefmt=datefmt,
                       reset=True,
                       log_colors={
                               DEBUG:cyan,
                               INFO: green,
                            WARNING:yellow,
                            ERROR: red,
                            CRITICAL:red,bg_white
                            },
                       secondary_log_colors={},
                       style=%
                       )

#设置输出渠道--输出到控制台
hd_1 = logging.StreamHandler()
#在handler上指定日志内容格式
hd_1.setFormatter(formatter)


#第五步:将headler添加到日志logger上
logger.addHandler(hd_1)

#第六步:调用输出方法
logger.debug("我是debug级别的日志")
logger.info("我是info级别的日志")
logger.warning("我是warning级别的日志")
logger.critical("我的critical级别的日志")
logger.error("我是error级别的日志输出")

代码运行结果:

技术分享图片

例3:secondary_log_color的使用

import logging
from logging.handlers import RotatingFileHandler
from colorlog import ColoredFormatter

#第一步:创建一个日志收集器logger
logger = logging.getLogger("autotest")

#第二步:修改日志的输出级别
logger.setLevel(logging.DEBUG)

#第三步:设置输出的日志内容格式
fmt = "%(log_color)s%(asctime)s  %(log_color)s%(filename)s  %(log_color)s%(funcName)s [line:%(log_color)s%(lineno)d] %(log_color)s%(levelname)s %(message_log_color)s%(message)s"
datefmt = %a, %d %b %Y %H:%M:%S

formatter = ColoredFormatter(fmt=fmt,
                       datefmt=datefmt,
                       reset=True,
                       secondary_log_colors={
                           ‘message‘: {
                               ‘ERROR‘: ‘red‘,
                               ‘CRITICAL‘: ‘yellow‘,
                               ‘WARNING‘: ‘green‘
                           }
                       },
                       style=%
                       )

#设置输出渠道--输出到控制台
hd_1 = logging.StreamHandler()
#在handler上指定日志内容格式
hd_1.setFormatter(formatter)


#第五步:将headler添加到日志logger上
logger.addHandler(hd_1)

#第六步:调用输出方法
logger.debug("我是debug级别的日志")
logger.info("我是info级别的日志")
logger.warning("我是warning级别的日志")
logger.critical("我的critical级别的日志")
logger.error("我是error级别的日志输出")

代码运行结果:

技术分享图片

 

colorlog的三个例子

标签:evel   日志收集   指定   fun   div   res   from   cname   五步   

原文地址:https://www.cnblogs.com/cnhkzyy/p/9574126.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!