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

 

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级别的日志输出")

代码运行结果:

 


__EOF__

本文作者cnhkzyy
本文链接https://www.cnblogs.com/my_captain/p/9574126.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   cnhkzyy  阅读(1127)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示