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使用xauth方式登录饭否网然后发消息
Apr 11 Python
python使用PythonMagick将jpg图片转换成ico图片的方法
Mar 26 Python
python中while循环语句用法简单实例
May 07 Python
在Python中使用swapCase()方法转换大小写的教程
May 20 Python
通过python+selenium3实现浏览器刷简书文章阅读量
Dec 26 Python
python执行系统命令后获取返回值的几种方式集合
May 12 Python
python opencv 读取本地视频文件 修改ffmpeg的方法
Jan 26 Python
Python + Flask 实现简单的验证码系统
Oct 01 Python
Python matplotlib以日期为x轴作图代码实例
Nov 22 Python
Python写捕鱼达人的游戏实现
Mar 31 Python
如何在vscode中安装python库的方法步骤
Jan 06 Python
Python机器学习之逻辑回归
May 11 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抽象类用法实例分析
2015/07/07 PHP
php抽奖概率算法(刮刮卡,大转盘)
2020/04/17 PHP
PHP常见数组排序方法小结
2018/08/20 PHP
js中事件的处理与浏览器对象示例介绍
2013/11/29 Javascript
IE与FF下javascript获取网页及窗口大小的区别详解
2014/01/14 Javascript
Javascript中引用示例介绍
2014/02/21 Javascript
浅析Node.js 中 Stream API 的使用
2015/10/23 Javascript
Javascript实现图片轮播效果(二)图片序列节点的控制实现
2016/02/17 Javascript
vue实现滑动超出指定距离回顶部功能
2019/07/31 Javascript
Echarts实现单条折线可拖拽效果
2019/12/19 Javascript
JavaScript对象原型链原理解析
2020/01/22 Javascript
JS运算符优先级与表达式示例详解
2020/09/04 Javascript
vue 动态创建组件的两种方法
2020/12/31 Vue.js
使用js原生实现年份轮播选择效果实例
2021/01/12 Javascript
python 控制语句
2011/11/03 Python
pycharm 使用心得(五)断点调试
2014/06/06 Python
Python守护线程用法实例
2017/06/23 Python
基于python实现KNN分类算法
2020/04/23 Python
Python3实现从排序数组中删除重复项算法分析
2019/04/03 Python
使用html5实现表格实现标题合并的实例代码
2019/05/13 HTML / CSS
美国经典刺绣和字母儿童服装特卖:Smocked Auctions
2018/07/16 全球购物
《都江堰》教学反思
2014/02/07 职场文书
个人自我剖析材料
2014/02/07 职场文书
室内设计专业自荐信
2014/05/31 职场文书
倡导文明标语
2014/06/16 职场文书
置业顾问岗位职责
2015/02/09 职场文书
2015年保卫科工作总结
2015/05/14 职场文书
2015年学生资助工作总结
2015/05/25 职场文书
2016年教师寒假学习心得体会
2015/10/09 职场文书
2016民族团结先进个人事迹材料
2016/02/26 职场文书
世界文化遗产导游词
2019/08/07 职场文书
喜迎建国70周年:有关爱国的名言名句
2019/09/24 职场文书
2019年图书室自查报告范本
2019/10/12 职场文书
Linux安装Nginx步骤详解
2021/03/31 Servers
python实现大文本文件分割成多个小文件
2021/04/20 Python
关于vue-router-link选择样式设置
2022/04/30 Vue.js