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


猜你喜欢
- 具体代码如下所示:import sysimport osclass Logger(object): def __init__(s
- 直接在线安装1、File->Settings->Plugins->Install JetBrains Plugins2、点
- 本文实例讲述了PHP基于迭代实现文件夹复制、删除、查看大小等操作的方法。分享给大家供大家参考,具体如下:前面一篇 PHP递归实现文件夹的复制
- 1.字符串定义# coding:utf-8if __name__ == '__main__': &
- 如下所示:# coding=utf-8import signalimport timedef set_timeout(num, callba
- 定时刷新的不足与改进web开发中可能遇到这样的场景:网页里的某一块区域里写了一些内容,但这些内容不是固定的,即使看网页的人没有做任何操作,它
- Line plotsAxes3D.plot(xs, ys, *args, **kwargs)绘制2D或3D数据参数描述xs, ysX轴,Y轴
- 本文根据自己初学经验编写的使用xlwt模块设置单元格的一些基本样式,如设置单元格的背景颜色,下框线,字体,字体的颜色,设置列宽行高,插入简单
- asp连接mysql的问题ASP连接Mysql数据库的问题。下了一个MySql 的ODBC驱动。做了个小测试。顺利通过。先记录下来,中间还有
- 安装数据可视化模块matplotlib:pip install matplotlib导入matplotlib模块下的pyplot1 折线图f
- this 的定义表示当前执行代码的环境对象 因此可将 this 的剖析分为“全局环境” 和 “函数环境” 两种类型的环境对象全局环
- 上一章实现了登录的部分功能,之所以说是部分功能,是因为用户名和密码写成固定值肯定是不可以的,一个整体的功能,至少需要注册,登录,密码修改等,
- 本文总结了input的各种使用方法,挺全面的1.取消按钮按下时的虚线框在input里添加属性值 hideFocus 或者 HideFocus
- 1.导入依赖包import ( "github.com/spf13/viper")2.编写ya
- 在Soundbreak我们每天24小时不间断地播放实况音频和视频,所以对于MySQL的新增的复制特性,我们不能做出很令人信服的测试。通过测试
- 我就废话不多说了,大家还是直接看代码吧~-- 查看获取表内字段注释:show full columns from tablename;--
- Symfony2是一个基于PHP语言的Web开发框架,有着开发速度快、性能高等特点。本文以一个程序示例的实现过程详细叙述了Symfony2框
- 症状: 访问asp网页的时候出现如下错误:Server object error ''ASP 0178 : 80070005
- 目录前言1. 效果图2. 原理3. 源码3.1 Numpy实现傅里叶变换3.2 OpenCV实现傅里叶变换3.3 HPF or LPF?参考
- 一、发送消息import smtplibfrom email.mime.text import MIMETextfrom email.hea