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
총결산이상 은 이 글 의 전체 내용 입 니 다.본 논문 의 내용 이 여러분 의 학습 이나 업무 에 어느 정도 도움 이 되 기 를 바 랍 니 다.궁금 한 점 이 있 으 시 면 댓 글 을 남 겨 주 셔 서 저희 에 대한 지지 에 감 사 드 립 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
로마 숫자를 정수로 또는 그 반대로 변환그 중 하나는 로마 숫자를 정수로 변환하는 함수를 만드는 것이었고 두 번째는 그 반대를 수행하는 함수를 만드는 것이었습니다. 문자만 포함합니다'I', 'V', 'X', 'L', 'C', 'D', 'M' ; 문자열이 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.