Python 로깅 모듈 예제 및 개선 사항
많은 애플리케이션에는 시스템 작동 상태를 쉽게 추적할 수 있도록 시스템 작동 중에 일부 주요 정보를 기록하는 데 사용되는 로그 모듈이 있습니다. Python에서는 이미 간단하고 사용하기 쉽고 강력한 로깅 모듈인 로깅을 제공하므로 타사 로깅 구성 요소가 필요하지 않습니다.
python은 객체의 모든 속성 값을 인쇄합니다.
def prn_obj(obj): print '\n'.join(['%s:%s' % item for item in obj.__dict__.items()])
Python 로거 객체 속성(위 함수로 획득)
name:get_data parent:<logging.RootLogger instance at 0x1d8bd88> handlers:[<logging.FileHandler instance at 0x21bcc68>] level:10 disabled:1 #当前的logger是否有效,默认为0 manager:<logging.Manager instance at 0x1d8bea8> propagate:0 #是否将本级日志 filters:[]
일부 로그를 출력할 수 없습니다
파일: logger.conf
[formatters] keys=default [formatter_default] format=%(asctime)s - %(name)s - %(levelname)s - %(message)s class=logging.Formatter [handlers] keys=console, error_file [handler_console] class=logging.StreamHandler formatter=default args=tuple() [handler_error_file] class=logging.FileHandler level=INFO formatter=default args=("logger.log", "a") [loggers] keys=root [logger_root] level=DEBUG formatter=default handlers=console,error_file
파일: logger.py
#!/bin/env python import logging from logging.config import logging class Test(object): """docstring for Test""" def __init__(self): logging.config.fileConfig("logger.conf") self.logger = logging.getLogger(__name__) def test_func(self): self.logger.error('test_func function') class Worker(object): """docstring for Worker""" def __init__(self): logging.config.fileConfig("logger.conf") self.logger = logging.getLogger(__name__) data_logger = logging.getLogger('data') handler = logging.FileHandler('./data.log') fmt = logging.Formatter('%(asctime)s|%(message)s') handler.setFormatter(fmt) data_logger.addHandler(handler) data_logger.setLevel(logging.DEBUG) self.data_logger = data_logger def test_logger(self): self.data_logger.error("test_logger function") instance = Test() self.data_logger.error("test_logger output") instance.test_func() def main(): worker = Worker() worker.test_logger() if __name__ == '__main__': main()
문제 1: 테스트 중에 test_logger 함수 명령문이 하나만 실행됩니다. 인쇄 가능
질문 2: 명령문은 data_logger에만 인쇄되지만 관련 로그는 로거 로그에도 나타납니다.
문제 1에 대한 해결 방법:
python -m pdb logger.py 문을 사용하여 스크립트를 디버깅하고 인스턴스 = Test() 문을 실행한 후 print 'n을 통해 이를 찾습니다. ' .join(['%s:%s' % item for item in self.data_logger.__dict__.items()]) 디버깅 문에서는 data_logger의 비활성화 속성 값이 0에서 True로 변경되었음을 알 수 있습니다. 로거의 해당 속성도 변경되었습니다. 이 변경으로 인해 로거 개체가 로깅을 중지합니다. Python 로깅 모듈의 관련 매뉴얼을 참조하면 "fileConfig() 함수는 이전 버전과의 호환성을 이유로 True로 설정된 기본 매개변수인 비활성화_기존_로거를 사용합니다. 이는 원하는 것일 수도 있고 아닐 수도 있습니다. fileConfig() 호출 이전에 존재했던 로거는 구성에서 명시적으로 이름이 지정되지 않는 한 비활성화됩니다.” 즉, fileconfig() 함수를 호출하면 이전에 존재했던 모든 로거가 비활성화됩니다. Python 2.7 버전에서는 fileConfig() 함수가 매개변수logging.config.fileConfig(fname, defaults=None, disable_existing_loggers=True)를 추가하여 원래 로거를 비활성화하지 않으려면 비활성화_기존_로거를 FALSE로 명시적으로 설정할 수 있습니다. 위 코드의 Test 클래스에 있는 login.config.fileConfig 함수를 login.config.fileConfig("./logger.conf", 비활성화_existing_loggers=0) 으로 변경하면 문제를 해결할 수 있습니다. 그러나 이 코드는 동일한 프로그램에 있기 때문에 다시 로드하기 위해 login.config.fileConfig 함수를 호출하지 않고도 login.getLogger(LOGGOR_NAME) 함수를 직접 사용하여 동일한 로거를 참조할 수 있습니다.
문제 2에 대한 해결 방법:
로거 개체에는 전파 속성이 있습니다. 이 속성이 True이면 출력할 정보가 로거의 모든 상위 로거에 푸시됩니다. 이러한 상위 로거에 해당하는 핸들러는 수신된 정보를 관련 로그에 인쇄합니다. 관련 루트 로거 속성은 logger.conf 구성 파일에서 구성됩니다. 이 루트 로거는 기본 로거 로그입니다.
수정된 내용은 다음과 같습니다.
파일: logger.conf
[formatters] keys=default, data [formatter_default] format=%(asctime)s - %(name)s - %(levelname)s - %(message)s class=logging.Formatter [formatter_data] format=%(asctime)s|%(message)s class=logging.Formatter [handlers] keys=console, error_file, data_file [handler_console] class=logging.StreamHandler formatter=default args=tuple() [handler_error_file] class=logging.FileHandler level=INFO formatter=default args=("logger.log", "a") [handler_data_file] class=logging.FileHandler level=INFO formatter=data args=("data_new.log", "a") [loggers] keys=root, data [logger_root] level=DEBUG handlers=console,error_file [logger_data] level=DEBUG handlers=data_file qualname=data propagate=0
파일: logger. py
#!/bin/env python import logging from logging.config import logging class Test(object): """docstring for Test""" def __init__(self): self.logger = logging.getLogger(__name__) def test_func(self): self.logger.error('test_func function') class Worker(object): """docstring for Worker""" def __init__(self): logging.config.fileConfig("logger.conf") self.logger = logging.getLogger(__name__) self.data_logger = logging.getLogger('data') def test_logger(self): self.data_logger.error("test_logger function") instance = Test() self.data_logger.error("test_logger output") instance.test_func() def main(): worker = Worker() worker.test_logger() if __name__ == '__main__': main()
더 많은 Python 로깅 모듈 예제와 개선 관련 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Linux 터미널에서 Python 버전을 보려고 할 때 Linux 터미널에서 Python 버전을 볼 때 권한 문제에 대한 솔루션 ... Python을 입력하십시오 ...

Python의 Pandas 라이브러리를 사용할 때는 구조가 다른 두 데이터 프레임 사이에서 전체 열을 복사하는 방법이 일반적인 문제입니다. 두 개의 dats가 있다고 가정 해

10 시간 이내에 컴퓨터 초보자 프로그래밍 기본 사항을 가르치는 방법은 무엇입니까? 컴퓨터 초보자에게 프로그래밍 지식을 가르치는 데 10 시간 밖에 걸리지 않는다면 무엇을 가르치기로 선택 하시겠습니까?

Fiddlerevery Where를 사용할 때 Man-in-the-Middle Reading에 Fiddlereverywhere를 사용할 때 감지되는 방법 ...

정규 표현식은 프로그래밍의 패턴 일치 및 텍스트 조작을위한 강력한 도구이며 다양한 응용 프로그램에서 텍스트 처리의 효율성을 높입니다.

Uvicorn은 HTTP 요청을 어떻게 지속적으로 듣습니까? Uvicorn은 ASGI를 기반으로 한 가벼운 웹 서버입니다. 핵심 기능 중 하나는 HTTP 요청을 듣고 진행하는 것입니다 ...

파이썬에서 문자열을 통해 객체를 동적으로 생성하고 메소드를 호출하는 방법은 무엇입니까? 특히 구성 또는 실행 해야하는 경우 일반적인 프로그래밍 요구 사항입니다.

이 기사는 Numpy, Pandas, Matplotlib, Scikit-Learn, Tensorflow, Django, Flask 및 요청과 같은 인기있는 Python 라이브러리에 대해 설명하고 과학 컴퓨팅, 데이터 분석, 시각화, 기계 학습, 웹 개발 및 H에서의 사용에 대해 자세히 설명합니다.
