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以上级别日志内容:

python利用logging模块实现根据日志级别打印不同颜色日志的代码案例

log.txt文件中写入了error及critical级别日志内容:

python利用logging模块实现根据日志级别打印不同颜色日志的代码案例

补充(python自带的格式化字符串):

python利用logging模块实现根据日志级别打印不同颜色日志的代码案例

python利用logging模块实现根据日志级别打印不同颜色日志的代码案例

来源:https://www.cnblogs.com/eliwang/p/16708787.html

标签:python,logging,打印不同颜色日志
0
投稿

猜你喜欢

  • Python基于递归算法实现的汉诺塔与Fibonacci数列示例

    2021-07-01 15:57:12
  • Python延时操作实现方法示例

    2023-08-25 04:04:50
  • python使用rabbitmq实现网络爬虫示例

    2022-04-20 20:11:58
  • python里读写excel等数据文件的6种常用方式(小结)

    2021-04-09 08:11:52
  • Python Parser的用法

    2022-05-23 23:53:55
  • 设计的商业价值

    2009-08-13 14:43:00
  • Python3中小括号()、中括号[]、花括号{}的区别详解

    2022-05-31 09:20:36
  • python中数字列表转化为数字字符串的实例代码

    2021-04-30 02:46:45
  • Python 详解爬取并统计CSDN全站热榜标题关键词词频流程

    2021-08-09 19:41:14
  • Python下载网络小说实例代码

    2023-08-01 18:22:17
  • python分析作业提交情况

    2023-07-29 20:59:31
  • 设置密码保护的SqlServer数据库备份文件与恢复文件的方法

    2011-11-03 16:55:30
  • python处理RSTP视频流过程解析

    2023-11-22 00:54:55
  • Python Web框架Flask中使用新浪SAE云存储实例

    2022-11-03 06:27:16
  • ASP页面内VBScript和JScript的交互

    2007-09-11 13:49:00
  • 利用python进行接口测试及类型介绍

    2021-02-11 21:27:01
  • ASP中从数据库读取二进制文件数据代码

    2010-04-24 15:44:00
  • Python数据类型之Tuple元组实例详解

    2023-02-17 05:24:01
  • Golang 使用http Client下载文件的实现方法

    2023-07-21 07:32:23
  • python使用wxpy实现微信消息防撤回脚本

    2023-08-22 21:21:58
  • asp之家 网络编程 m.aspxhome.com