Python 根据日志级别打印不同颜色的日志的方法示例
本文介绍了Python根据日志级别打印不同颜色的日志的方法示例,分享给大家,具体如下:
#-*-coding:UTF-8-*-
importlogging
importos
importtime
classlogger(object):
"""
终端打印不同颜色的日志,在pycharm中如果强行规定了日志的颜色,这个方法不会起作用,但是
对于终端,这个方法是可以打印不同颜色的日志的。
"""
#在这里定义StreamHandler,可以实现单例,所有的logger()共用一个StreamHandler
ch=logging.StreamHandler()
def__init__(self):
self.logger=logging.getLogger()
ifnotself.logger.handlers:
#如果self.logger没有handler,就执行以下代码添加handler
self.logger.setLevel(logging.DEBUG)
fromserviceProgram.utils.FileUtilimportFileUtil
rootPath=FileUtil.getProgrameRootPath()
self.log_path=rootPath+'/logs'
ifnotos.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)
defdebug(self,message):
self.fontColor('\033[0;32m%s\033[0m')
self.logger.debug(message)
definfo(self,message):
self.fontColor('\033[0;34m%s\033[0m')
self.logger.info(message)
defwarning(self,message):
self.fontColor('\033[0;37m%s\033[0m')
self.logger.warning(message)
deferror(self,message):
self.fontColor('\033[0;31m%s\033[0m')
self.logger.error(message)
defcritical(self,message):
self.fontColor('\033[0;35m%s\033[0m')
self.logger.critical(message)
deffontColor(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开头,即用\033来完成(ESC的ASCII码用十进制表示是27,用八进制表示就是033)。
书写格式:
开头部分:\033[显示方式;前景色;背景色m+结尾部分:\033[0m
注意:开头部分的三个参数:显示方式,前景色,背景色是可选参数,可以只写其中的某一个;另外由于
表示三个参数不同含义的数值都是唯一的没有重复的,所以三个参数的书写先后顺序没有固定要求,系统
都能识别;但是,建议按照默认的格式规范书写。
对于结尾部分,其实也可以省略,但是为了书写规范,建议\033[***开头,\033[0m结尾。
数值表示的参数含义:
常见开头格式:
- \033[0m 默认字体正常显示,不高亮
 - \033[32;0m 红色字体正常显示
 - \033[1;32;40m 显示方式:高亮 字体前景色:绿色 背景色:黑色
 - \033[0;31;46m 显示方式:正常 字体前景色:红色 背景色:青色
 
实例:
(1)print("\033[1;31;40m您输入的帐号或密码错误!\033[0m")  
上方代码的输出格式为:字体高亮,红色前景,黄色背景     PS:前景色也就是字体的颜色
(2)print("\033[0;31m%s\033[0m"%"输出红色字符")
#上方代码的输出格式为:字体默认,红色前景
LOG_INFO='INFO'
LOG_ERROR='ERROR'
LOG_WARNING='WARNING'
LOG_NOTIFY='NOTIFY'
LOG_DEBUG='DEBUG'
LOG_USER='USER'
definfo_log(value):
iflog_level>3:
print("\033[0;37;40m%s\033[0m"%value)
deferror_log(value):
iflog_level!=0:
print("\033[0;31;40m%s\033[0m"%value)
defwarning_log(value):
iflog_level>1:
print("\033[0;33;40m%s\033[0m"%value)
defdebug_log(value):
iflog_level>5:
print("\033[0;34;40m%s\033[0m"%value)
defnotify_log(value):
iflog_level>2:
print("\033[0;36;40m%s\033[0m"%value)
defuser_log(value):
iflog_level>4:
print("\033[0;32;40m%s\033[0m"%value)
defZLOG(log_type,value):
switcher={
'INFO':info_log,
'ERROR':error_log,
'WARNING':warning_log,
'DEBUG':debug_log,
'NOTIFY':notify_log,
'USER':user_log
}
returnswitcher[log_type](value)
test="helloworld"
ZLOG(LOG_INFO,"outputinfolog%s"%test)
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。