Python 根据日志级别打印不同颜色的日志的方法示例


Posted in Python onAugust 08, 2019

本文介绍了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('\033[0;32m%s\033[0m')
    self.logger.debug(message)
 
  def info(self, message):
    self.fontColor('\033[0;34m%s\033[0m')
    self.logger.info(message)
 
  def warning(self, message):
    self.fontColor('\033[0;37m%s\033[0m')
    self.logger.warning(message)
 
  def error(self, message):
    self.fontColor('\033[0;31m%s\033[0m')
    self.logger.error(message)
 
  def critical(self, message):
    self.fontColor('\033[0;35m%s\033[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开头,即用\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'
 
def info_log(value):
  if log_level > 3:
    print("\033[0;37;40m%s\033[0m"%value)
 
def error_log(value):
  if log_level != 0:
    print("\033[0;31;40m%s\033[0m"%value)
 
def warning_log(value):
  if log_level > 1:
    print("\033[0;33;40m%s\033[0m"%value)
 
def debug_log(value):
  if log_level > 5:
    print("\033[0;34;40m%s\033[0m"%value)
 
def notify_log(value):
  if log_level > 2:
    print("\033[0;36;40m%s\033[0m"%value)
 
def user_log(value):
  if log_level > 4:
    print("\033[0;32;40m%s\033[0m"%value)
 
def ZLOG(log_type,value):
  switcher={
    'INFO':info_log,
    'ERROR':error_log,
    'WARNING':warning_log,
    'DEBUG':debug_log,
    'NOTIFY':notify_log,
    'USER':user_log
  }
  return switcher[log_type](value)
 
test="hello world"
ZLOG(LOG_INFO,"output info log %s"%test)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python中的多重继承实例讲解
Sep 28 Python
Django1.7+python 2.78+pycharm配置mysql数据库教程
Nov 18 Python
浅谈Python的垃圾回收机制
Dec 17 Python
Python 创建新文件时避免覆盖已有的同名文件的解决方法
Nov 16 Python
python中几种自动微分库解析
Aug 29 Python
django实现模型字段动态choice的操作
Apr 01 Python
浅谈cv2.imread()和keras.preprocessing中的image.load_img()区别
Jun 12 Python
增大python字体的方法步骤
Jul 05 Python
详解python tkinter 图片插入问题
Sep 03 Python
python matplotlib绘制三维图的示例
Sep 24 Python
python使用正则表达式匹配txt特定字符串(有换行)
Dec 09 Python
Pandas 数据编码的十种方法
Apr 20 Python
Python学习笔记之错误和异常及访问错误消息详解
Aug 08 #Python
Python实现直方图均衡基本原理解析
Aug 08 #Python
python获取指定日期范围内的每一天,每个月,每季度的方法
Aug 08 #Python
Python 调用 Outlook 发送邮件过程解析
Aug 08 #Python
python判断自身是否正在运行的方法
Aug 08 #Python
Python 日期区间处理 (本周本月上周上月...)
Aug 08 #Python
python各类经纬度转换的实例代码
Aug 08 #Python
You might like
php语言流程控制中的主动与被动
2012/11/05 PHP
php实现的RSS生成类实例
2015/04/23 PHP
php获取网站百度快照日期的方法
2015/07/29 PHP
Joomla开启SEF的方法
2016/05/04 PHP
PHP封装函数实现生成随机的字符串验证码
2017/01/24 PHP
PHP调用接口API封装的例子
2019/10/11 PHP
js跟随滚动条滚动浮动代码
2009/12/31 Javascript
jQeury淡入淡出需要注意的问题
2010/09/08 Javascript
js处理自己不能定义二维数组的方法详解
2014/03/03 Javascript
javascript根据时间生成m位随机数最大13位
2014/10/30 Javascript
node.js微信公众平台开发教程
2016/03/04 Javascript
vue中的计算属性的使用和vue实例的方法示例
2017/12/04 Javascript
详解vue+webpack+express中间件接口使用
2018/07/17 Javascript
layui框架table 数据表格的方法级渲染详解
2018/08/19 Javascript
JavaScript变量作用域及内存问题实例分析
2019/06/10 Javascript
jQuery 淡入/淡出效果函数用法分析
2020/05/19 jQuery
使用python BeautifulSoup库抓取58手机维修信息
2013/11/21 Python
利用python获取Ping结果示例代码
2017/07/06 Python
python模拟事件触发机制详解
2018/01/19 Python
解决python中使用plot画图,图不显示的问题
2018/07/04 Python
python多线程抽象编程模型详解
2019/03/20 Python
Flask框架路由和视图用法实例分析
2019/11/07 Python
Python实现密钥密码(加解密)实例详解
2020/04/26 Python
tensorflow dataset.shuffle、dataset.batch、dataset.repeat顺序区别详解
2020/06/03 Python
Python使用tkinter实现小时钟效果
2021/02/22 Python
英国时尚配饰、珠宝和服装网站:KJ Beckett
2020/01/23 全球购物
linux面试题参考答案(2)
2015/12/06 面试题
简单叙述一下MYSQL的优化
2016/05/09 面试题
医务人员自我评价
2014/01/26 职场文书
计算机专业职业规划
2014/02/28 职场文书
交通安全寄语大全
2014/04/08 职场文书
2015年业务员工作总结范文
2015/04/07 职场文书
大学生村官工作总结2015
2015/04/09 职场文书
股东大会通知
2015/04/24 职场文书
2016教师校本培训心得体会
2016/01/08 职场文书
Win11 22H2 2022怎么更新? 获得Win1122H22022版本升级技巧
2022/09/23 数码科技