Python Logger 인쇄 기능 을 실현 하 는 방법 에 대한 상세 한 설명

머리말
Python 에 서 는 logger 인쇄 에 사용 되 는 세트 가 logging 이 라 고 알려 져 있 지만 이 세트 는 하나의 문자열 형식의 logger 인쇄 정보 만 받 습 니 다.따라서 인쇄 할 정 보 를 미리 문자열 로 연결 해 야 합 니 다.코드 의 깔끔 함 에 좋 지 않 습 니 다.
저 는 logging 을 바탕 으로 자바 와 유사 한 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
총결산
이상 은 이 글 의 전체 내용 입 니 다.본 논문 의 내용 이 여러분 의 학습 이나 업무 에 어느 정도 도움 이 되 기 를 바 랍 니 다.궁금 한 점 이 있 으 시 면 댓 글 을 남 겨 주 셔 서 저희 에 대한 지지 에 감 사 드 립 니 다.

좋은 웹페이지 즐겨찾기