Python实现Logger打印功能的方法详解


Posted in Python onSeptember 01, 2017

前言

众所周知在Python中有专门用于logger打印的套件叫logging,但是该套件logger仅接收一个字符串类型的logger打印信息。因此,我们在使用是需要先提前将要打印的信息拼接成一个字符串之后才行,这样对于代码的整洁性并不好。

我在logging的基础上实现了一个类似于Java的logback的logger打印工具,实现比较简单,能够应对一些简单的logger打印需求,希望对大家能有帮助。下面话不多说了,来一起看看详细的介绍:

LoggerFactory

该类用作生成其他调用类的logger实例,并保存这些实例。

'''
Created on 2017年7月20日
Logger工厂,保存每个类的Logger实例
'''
from slient.bigdata.common.logger import Logger
import logging

class LoggerFactory :
 LOG_FILENAME='bigdata_python.log' #logger保存文件
 TYPE = "CONSOLE"     #logger打印类型
 #TYPE = "FILE"

 LEVEL = logging.DEBUG    #logger级别
 #LEVEL = logging.INFO

 loggerDict = {}

 #对外部开放的Logger调用方法
 @staticmethod
 def getLogger(className) -> Logger:
  if className in LoggerFactory.loggerDict.keys() : 
   logger = LoggerFactory.loggerDict[className]
   if not logger : 
    logger = LoggerFactory.__initLogger(className)
  else : 
   logger = LoggerFactory.__initLogger(className)
  return logger

 #生成Logger实例
 @staticmethod
 def __initLogger(className) -> Logger: 
  logger = logging.getLogger(className)
  # 设置logger的level为DEBUG
  logger.setLevel(LoggerFactory.LEVEL)
  #设置Logger格式
  formatter = logging.Formatter('[%(asctime)s] [%(name)s] [%(levelname)s]: %(message)s')

  if LoggerFactory.TYPE == 'CONSOLE' : 
   # 创建输出日志到控制台的StreamHandler
   handler = logging.StreamHandler()
  else : 
   # 创建输出日志到文件Handler
   handler = logging.FileHandler(LoggerFactory.LOG_FILENAME)

  #添加格式 
  handler.setFormatter(formatter)
  # 给logger添加上handler
  logger.addHandler(handler)

  localLogger = Logger(logger)
  LoggerFactory.loggerDict[className] = localLogger
  return localLogger

Logger

该类主要实现了对logging的一些方法的封装,比较简单。

'''
Created on 2017年7月5日
日志处理
'''
import logging
import string

class Logger :

 def __init__(self, logger : logging):
  self.logger = logger

 def info(self, formatStr:string, *objs):
  self.logger.info(formatStr.format(*objs))

 def debug(self, formatStr:string, *objs):
  self.logger.debug(formatStr.format(*objs))

 def error(self, formatStr:string, *objs):
  self.logger.error(formatStr.format(*objs))

测试

logger = LoggerFactory.getLogger("Test")
logger.info("打印log1:{}, 打印log2:{}", 666, "我是log2")

测试结果:

[2017-07-20 16:43:00,821] [Test] [INFO]: 打印log1:666, 打印log2:我是log2

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Python 相关文章推荐
Python实现备份文件实例
Sep 16 Python
Python内置函数delattr的具体用法
Nov 23 Python
Python MySQLdb 使用utf-8 编码插入中文数据问题
Mar 13 Python
PyQt5每天必学之工具提示功能
Apr 19 Python
selenium在执行phantomjs的API并获取执行结果的方法
Dec 17 Python
Python lambda表达式用法实例分析
Dec 25 Python
Python基本数据结构与用法详解【列表、元组、集合、字典】
Mar 23 Python
Python中函数的返回值示例浅析
Aug 28 Python
Python基于requests库爬取网站信息
Mar 02 Python
python+requests接口压力测试500次,查看响应时间的实例
Apr 30 Python
解决Django响应JsonResponse返回json格式数据报错问题
Aug 09 Python
Python之京东商品秒杀的实现示例
Jan 06 Python
Python数据分析之如何利用pandas查询数据示例代码
Sep 01 #Python
Python使用回溯法子集树模板解决迷宫问题示例
Sep 01 #Python
Python基于回溯法子集树模板实现8皇后问题
Sep 01 #Python
Python3.x对JSON的一些操作示例
Sep 01 #Python
Python+Socket实现基于TCP协议的客户与服务端中文自动回复聊天功能示例
Aug 31 #Python
Python+Socket实现基于UDP协议的局域网广播功能示例
Aug 31 #Python
python requests 使用快速入门
Aug 31 #Python
You might like
php实现从ftp服务器上下载文件树到本地电脑的程序
2009/02/10 PHP
JSON在PHP中的应用介绍
2012/09/08 PHP
解析PHP对现有搜索引擎的调用
2013/06/25 PHP
laravel-admin 实现在指定的相册下添加照片
2019/10/21 PHP
PHPStorm2020.1永久激活及下载更新至2020(推荐)
2020/09/25 PHP
用js查找法实现当前栏目的高亮显示的代码
2007/11/24 Javascript
jQuery中toggle()函数的使用实例
2015/04/17 Javascript
基于jquery实现全屏滚动效果
2015/11/26 Javascript
Fullpage.js固定导航栏-实现定位导航栏
2016/03/17 Javascript
jquery判断input值不为空的方法
2016/06/05 Javascript
Node.js  REPL (交互式解释器)实例详解
2017/08/06 Javascript
JavaScript变量类型以及变量作用域详解
2017/08/14 Javascript
vue实现长图垂直居上 vue实现短图垂直居中
2017/10/18 Javascript
vue-cli3.0配置及使用注意事项详解
2018/09/05 Javascript
在vue-cli 3中给stylus、sass样式传入共享的全局变量
2019/08/12 Javascript
vuex管理状态 刷新页面保持不被清空的解决方案
2019/11/11 Javascript
vue使用keep-alive实现组件切换时保存原组件数据方法
2020/10/30 Javascript
python求pi的方法
2014/10/08 Python
Python实现的最近最少使用算法
2015/07/10 Python
从局部变量和全局变量开始全面解析Python中变量的作用域
2016/06/16 Python
Python logging管理不同级别log打印和存储实例
2018/01/19 Python
python 表格打印代码实例解析
2019/10/12 Python
python修改文件内容的3种方法详解
2019/11/15 Python
使用Python将Exception异常错误堆栈信息写入日志文件
2020/04/08 Python
Python datetime模块的使用示例
2021/02/02 Python
美国女孩服装购物网站:Justice
2017/03/04 全球购物
旅游管理毕业生自荐信
2013/11/05 职场文书
服装设计专业自荐书范文
2013/12/30 职场文书
服务承诺书范文
2014/05/19 职场文书
小学生作文批改评语
2014/12/25 职场文书
承诺保证书格式
2015/02/28 职场文书
基层党建工作简报
2015/07/21 职场文书
pytorch 中nn.Dropout的使用说明
2021/05/20 Python
如何有效防止sql注入的方法
2021/05/25 SQL Server
Opencv中cv2.floodFill算法的使用
2021/06/18 Python
Golang并发操作中常见的读写锁详析
2021/08/30 Golang