python利用logging模块实现根据日志级别打印不同颜色日志的代码案例
作者:eliwang 时间:2022-03-21 14:58:07
logger:日志器对象,可通过logging.getLogger()方法获取
handler:处理器对象,将日志信息输出到指定位置,可通过logger.addHandler()方法进行添加
formatter:格式器对象,输出格式化日志字符串
有时候同一个应用程序有不同的日志需求,比如将error级别的日志在控制台输出,critical级别的日志写入日志文件中,这就需要不同的handler来实现,然后均通过logger.addHandler()方法进行添加
代码:
# coding:utf-8
import logging
import colorlog
class Log:
def __init__(self,name=None,log_level=logging.DEBUG):
# 获取logger对象
self.logger = logging.getLogger(name)
# 避免重复打印日志
self.logger.handlers = []
# 指定最低日志级别:(critical > error > warning > info > debug)
self.logger.setLevel(log_level)
# 日志格化字符串
console_fmt = '%(log_color)s%(asctime)s-%(threadName)s-%(filename)s-[line:%(lineno)d]-%(levelname)s: %(message)s'
file_fmt = '%(asctime)s-%(threadName)s-%(filename)s-[line:%(lineno)d]-%(levelname)s: %(message)s'
# 控制台输出不同级别日志颜色设置
color_config = {
'DEBUG': 'cyan',
'INFO': 'green',
'WARNING': 'yellow',
'ERROR': 'red',
'CRITICAL': 'purple',
}
console_formatter = colorlog.ColoredFormatter(fmt=console_fmt,log_colors=color_config)
file_formatter = logging.Formatter(fmt=file_fmt)
# 输出到控制台
console_handler = logging.StreamHandler()
# 输出到文件
file_handler = logging.FileHandler(filename=name,mode='a',encoding='utf-8')
# 设置日志格式
console_handler.setFormatter(console_formatter)
file_handler.setFormatter(file_formatter)
# 处理器设置日志级别,不同处理器可各自设置级别,默认使用logger日志级别
# console_handler.setLevel(logging.WARNING)
file_handler.setLevel(logging.ERROR) # 只有error和critical级别才会写入日志文件
# logger添加处理器
self.logger.addHandler(console_handler)
self.logger.addHandler(file_handler)
def debug(self,message):
self.logger.debug(message)
def info(self,message):
self.logger.info(message)
def warning(self,message):
self.logger.warning(message)
def error(self,message):
self.logger.error(message)
def critical(self,message):
self.logger.critical(message)
if __name__ == '__main__':
# 控制台只会显示warning及以上级别日志信息,而log.txt文件中则会记录error及以上级别日志信息
log = Log(name='log.txt',log_level=logging.WARNING)
log.debug('debug')
log.info('info')
log.warning('warning')
log.error('error')
log.critical('critical')
最终控制台按照指定颜色输出warning以上级别日志内容:
log.txt文件中写入了error及critical级别日志内容:
补充(python自带的格式化字符串):
来源:https://www.cnblogs.com/eliwang/p/16708787.html
标签:python,logging,打印不同颜色日志
0
投稿
猜你喜欢
使用pandas计算环比和同比的方法实例
2021-02-15 18:06:34
对python插入数据库和生成插入sql的示例讲解
2022-03-10 05:46:40
python中List添加与删除元素的几种方法实例
2021-10-07 09:13:36
详解python中的Turtle函数库
2021-10-17 19:50:45
Python学习笔记之读取文件、OS模块、异常处理、with as语法示例
2023-03-20 21:54:58
python判断数字是否是超级素数幂
2023-12-24 06:16:31
Python获取图像中像素点坐标实例代码
2021-02-20 19:42:05
python 列表降维的实例讲解
2023-08-28 16:44:54
Python ORM框架SQLAlchemy学习笔记之安装和简单查询实例
2022-06-30 14:21:34
使用Golang的Context管理上下文的方法
2023-06-29 06:37:23
解决python opencv无法显示图片的问题
2021-09-11 13:26:37
使用Python第三方库发送电子邮件的示例代码
2021-07-24 11:17:36
客户端限制只能上传jpg格式图片的js代码
2023-07-16 00:56:04
python区块链创建多个交易教程
2021-05-28 13:40:42
oracle-快速删除重复的记录
2008-01-16 19:12:00
浅谈信息可视化
2010-03-10 10:55:00
Python reversed函数及使用方法解析
2023-01-24 16:10:53
Python如何将函数值赋给变量
2022-01-01 22:58:22
python多进程重复加载的解决方式
2021-07-22 23:49:43
python操作openpyxl导出Excel 设置单元格格式及合并处理代码实例
2022-09-27 13:07:54