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爬虫教程之爬取百度贴吧并下载的示例
Mar 07 Python
Python计算三角函数之asin()方法的使用
May 15 Python
python截取两个单词之间的内容方法
Dec 25 Python
Tensorflow分类器项目自定义数据读入的实现
Feb 05 Python
使用Python正则表达式操作文本数据的方法
May 14 Python
pandas实现to_sql将DataFrame保存到数据库中
Jul 03 Python
python生成器推导式用法简单示例
Oct 08 Python
python隐藏类中属性的3种实现方法
Dec 19 Python
Python 之 Json序列化嵌套类方式
Feb 27 Python
python pandas利用fillna方法实现部分自动填充功能
Mar 16 Python
Python3爬虫关于识别点触点选验证码的实例讲解
Jul 30 Python
Python Selenium库的基本使用教程
Jan 04 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
解析thinkphp中的导入文件标签
2013/06/20 PHP
浅析Mysql 数据回滚错误的解决方法
2013/08/05 PHP
php使用cookie显示用户上次访问网站日期的方法
2015/01/26 PHP
PHP递归遍历指定目录的文件并统计文件数量的方法
2015/03/24 PHP
Windows2003下php5.4安装配置教程(IIS)
2016/06/30 PHP
php将html转为图片的实现方法
2017/05/19 PHP
JavaScript中变量提升 Hoisting
2012/07/03 Javascript
Table冻结表头示例代码
2013/08/20 Javascript
返回顶部按钮响应滚动且动态显示与隐藏
2014/10/14 Javascript
Jquery实现纵向横向菜单
2016/01/24 Javascript
jQuery实现点击后高亮背景固定显示的菜单效果【附demo源码下载】
2016/09/21 Javascript
canvas实现钟表效果
2017/02/13 Javascript
解决webpack打包速度慢的解决办法汇总
2017/07/06 Javascript
JavaScript实现一个带AI的井字棋游戏源码
2018/05/21 Javascript
JavaScript设计模式之观察者模式实例详解
2019/01/16 Javascript
Vue实现一个图片懒加载插件
2019/03/11 Javascript
python实现的防DDoS脚本
2011/02/08 Python
Python实现模拟时钟代码推荐
2015/11/08 Python
pytorch训练imagenet分类的方法
2018/07/27 Python
用Python批量把文件复制到另一个文件夹的实现方法
2019/08/16 Python
Python3.7实现验证码登录方式代码实例
2020/02/14 Python
python字符串判断密码强弱
2020/03/18 Python
实现ECharts双Y轴左右刻度线一致的例子
2020/05/16 Python
Python使用configparser读取ini配置文件
2020/05/25 Python
浅谈sklearn中predict与predict_proba区别
2020/06/28 Python
Pycharm无法打开双击没反应的问题及解决方案
2020/08/17 Python
OnePlus加拿大官网:中国国际化手机品牌
2020/10/13 全球购物
实习生自荐信范文
2013/11/13 职场文书
机电一体化自荐信
2013/12/10 职场文书
教师实习自我鉴定
2013/12/14 职场文书
后勤人员岗位职责
2013/12/17 职场文书
中国梦我的梦演讲稿
2014/04/23 职场文书
《蝙蝠和雷达》教学反思
2014/04/23 职场文书
励志广播稿300字(5篇)
2014/09/15 职场文书
2019年恭贺升学祝福语集锦
2019/08/15 职场文书
js面向对象编程OOP及函数式编程FP区别
2022/07/07 Javascript