未加星标

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

字体大小 | |
[开发(python) 所属分类 开发(python) | 发布者 店小二05 | 时间 | 作者 红领巾 ] 0人收藏点击收藏

前言

众所周知在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基础教程 python多线程 web开发工程师 软件开发工程师 软件开发流程

主题: JavaPython谢大需求
分页:12
转载请注明
本文标题:Python实现Logger打印功能的方法详解
本站链接:http://www.codesec.net/view/563781.html
分享请点击:


1.凡CodeSecTeam转载的文章,均出自其它媒体或其他官网介绍,目的在于传递更多的信息,并不代表本站赞同其观点和其真实性负责;
2.转载的文章仅代表原创作者观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,本站对该文以及其中全部或者部分内容、文字的真实性、完整性、及时性,不作出任何保证或承若;
3.如本站转载稿涉及版权等问题,请作者及时联系本站,我们会及时处理。
登录后可拥有收藏文章、关注作者等权限...
技术大类 技术大类 | 开发(python) | 评论(0) | 阅读(22)