Python:colorlog的三个例子
例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
'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:531509025
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
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级别的日志输出")
代码运行结果: