python利用logging模块实现根据日志级别打印不同颜色日志的代码案例
作者:eliwang 发布时间:2022-03-21 14:58:07
标签:python,logging,打印不同颜色日志
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
0
投稿
猜你喜欢
- 旋转椭圆实例代码:import matplotlib.pyplot as pltimport numpy as npfrom matplot
- 跨文件使用全局变量有多个py文件同时使用一个全局变量时,那应该如何使跨文件,用这个全局变量呢?1. 错误示范file1.py代码如下:num
- Mac 安装 Python3.10 并且配置环境一、Python的安装访问官网:https://www.python.org/选择系统(Ma
- 最近决定把MT的后台数据从Berkeley的文件DB转到MySQL。原因之一是使用关系数据库可以获得更多的灵活性,比如运行一条sql来变更
- memoryview() 函数返回给定参数的内存查看对象(Momory view)。语法memoryview 语法:memoryview(o
- 一、Sql Server中的日期与时间函数 1. 当前系统日期、时间 select getdate() 2. dateadd 在向指定日期加
- 李开复曾经在年前表示,谷歌公司会在今年春节期间,对Google谷歌的搜索结果页进行“从未有过的尝试”修改,以凸显农历春节的喜庆气氛。现在,输
- this指针是面向对象程序设计中的一项重要概念,它表示当前运行的对象。在实现对象的方法时,可以使用this指针来获得该对象自身的引用。和其他
- 声明定位元素:position属性值设置除默认值static以外的元素,包括relative,absolute,fixed。平台:win/I
- MVC设计模式MVC (Model-View-Controller) 是软件工程中常用的软件架构模式,它是一种分离业务逻辑与显示界面的设计方
- pytorch查看模型model参数parameters示例1:pytorch自带的faster r-cnn模型import torchim
- 随着互联网的飞速发展,很多主页都是越做越漂亮、越来越有个性。如果你是一个资深的网虫不会没有自己的主页吧!下面小弟就来谈谈如何使你的网上“小窝
- 首先安装需要的模块pip install aliyun-python-sdk-corepip install aliyun-python-s
- 本文实例讲述了js捐赠管理完整实现方法。分享给大家供大家参考。具体实现方法如下:index.html页面如下:<!DOCTYPE ht
- 1005:创建表失败1006:创建数据库失败1007:数据库已存在,创建数据库失败1008:数据库不存在,删除数据库失败1009:不能删除数
- 如下所示:import cv2import os#图片路径im_dir = '/home/suanfa/data/out/20170
- DDP 数据shuffle 的设置使用DDP要给dataloader传入sampler参数(torch.utils.data.distrib
- 1.列表推导式书写形式:[表达式 for 变量 in 列表] 或者 [表达式 for 变量
- 前言实际工作中,偶尔遇到如下情况,例如使用Pandas计算如下相关系数,并把结果写入Excel文件中。correlations = df.c
- 1. sys_getloadavg()sys_getloadavt()可以获得系 统负载情况。该函数返回一个包含三个元素的数组,每个元素分别