本文介绍了Python 根据日志级别打印不同颜色的日志的方法示例,分享给大家,具体如下:
# -*-coding:UTF-8-*-
import logging
import os
import time
class logger(object):
"""
终端打印不同颜色的日志,在pycharm中如果强行规定了日志的颜色, 这个方法不会起作用, 但是
对于终端,这个方法是可以打印不同颜色的日志的。
"""
#在这里定义StreamHandler,可以实现单例, 所有的logger()共用一个StreamHandler
ch = logging.StreamHandler()
def __init__(self):
self.logger = logging.getLogger()
if not self.logger.handlers:
#如果self.logger没有handler, 就执行以下代码添加handler
self.logger.setLevel(logging.DEBUG)
from serviceProgram.utils.FileUtil import FileUtil
rootPath = FileUtil.getProgrameRootPath()
self.log_path = rootPath + '/logs'
if not os.path.exists(self.log_path):
os.makedirs(self.log_path)
# 创建一个handler,用于写入日志文件
fh = logging.FileHandler(self.log_path + '/runlog' + time.strftime("%Y%m%d", time.localtime()) + '.log', encoding='utf-8')
fh.setLevel(logging.INFO)
# 定义handler的输出格式
formatter = logging.Formatter('[%(asctime)s] - [%(levelname)s] - %(message)s')
fh.setFormatter(formatter)
# 给logger添加handler
self.logger.addHandler(fh)
def debug(self, message):
self.fontColor(' 33[0;32m%s 33[0m')
self.logger.debug(message)
def info(self, message):
self.fontColor(' 33[0;34m%s 33[0m')
self.logger.info(message)
def warning(self, message):
self.fontColor(' 33[0;37m%s 33[0m')
self.logger.warning(message)
def error(self, message):
self.fontColor(' 33[0;31m%s 33[0m')
self.logger.error(message)
def critical(self, message):
self.fontColor(' 33[0;35m%s 33[0m')
self.logger.critical(message)
def fontColor(self, color):
#不同的日志输出不同的颜色
formatter = logging.Formatter(color % '[%(asctime)s] - [%(levelname)s] - %(message)s')
self.ch.setFormatter(formatter)
self.logger.addHandler(self.ch)
if __name__ == "__main__":
logger = logger()
logger.info("12345")
logger.debug("12345")
logger.warning("12345")
logger.error("12345")
实现过程:
终端的字符颜色是用转义序列控制的,是文本模式下的系统显示功能,和具体的语言无关。
转义序列是以ESC开头,即用 33来完成(ESC的ASCII码用十进制表示是27,用八进制表示就是033)。
书写格式:
开头部分: 33[显示方式;前景色;背景色m + 结尾部分: 33[0m
注意:开头部分的三个参数:显示方式,前景色,背景色是可选参数,可以只写其中的某一个;另外由于
表示三个参数不同含义的数值都是唯一的没有重复的,所以三个参数的书写先后顺序没有固定要求,系统
都能识别;但是,建议按照默认的格式规范书写。
对于结尾部分,其实也可以省略,但是为了书写规范,建议 33[***开头, 33[0m结尾。
数值表示的参数含义:
常见开头格式:


