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自带的格式化字符串):
到此这篇关于python利用logging模块实现根据日志级别打印不同颜色日志的文章就介绍到这了,更多相关python logging模块打印不同颜色日志内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
django框架model orM使用字典作为参数,保存数据的方法分析
这篇文章主要介绍了django框架model orM使用字典作为参数,保存数据的方法,结合实例形式分析了字典参数结合django model实现保存数据相关操作技巧,需要的朋友可以参考下2019-06-06Python读取配置文件-ConfigParser的二次封装方法
这篇文章主要介绍了Python读取配置文件-ConfigParser的二次封装方法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-02-02最新解决'nvidia-smi' 不是内部或外部命令也不是可运行的程序
使用cmd查看电脑显卡的信息,调用nvidia-smi查看显卡使用情况报错,提示'nvidia-smi' 不是内部或外部命令,也不是可运行的程序,本文给大家分享完美解决方案,感兴趣的朋友跟随小编一起看看吧2023-01-01Python网络编程使用select实现socket全双工异步通信功能示例
这篇文章主要介绍了Python网络编程使用select实现socket全双工异步通信功能,简单说明了select模块的功能及socket全双工异步通信功能的相关实现技巧,需要的朋友可以参考下2018-04-04
最新评论