sys.stdout을 로그 파일에 복제
Python에서 sys.stdout을 로그 파일에 복제하면 비침해적 솔루션을 제공할 수 있습니다. 애플리케이션 코드를 수정하지 않고 로깅합니다. 이를 수행하는 방법은 다음과 같습니다.
대화형 모드에서 출력을 화면에 표시하고 로그 파일에 기록하려는 경우 데몬 모드에서 사용된 논리를 되돌릴 수 있습니다. stdout 및 stderr를 리디렉션하는 대신 os.dup2를 사용하여 복제합니다.
아래 코드는 이를 보여줍니다.
import os, sys # Open the log file for writing without buffering so = se = open("a.log", 'w', 0) # Duplicate stdout and stderr to the log file os.dup2(sys.stdout.fileno(), so.fileno()) os.dup2(sys.stderr.fileno(), se.fileno())
이 접근 방식을 사용하면 시스템 호출의 출력을 포함한 모든 출력을 기록할 수 있습니다. 코드를 변경하지 않고.
또는 제공된 클래스에서 Tee 클래스를 활용할 수도 있습니다. snippet:
# Initialize a Tee object, redirecting stdout to a log file tee = Tee("a.log", 'w')
이 클래스는 모든 출력이 로그 파일과 표준 출력 모두에 기록되도록 보장하므로 애플리케이션 코드를 수정하지 않고 대화형 모드로 로그인할 수 있는 편리한 솔루션입니다.
위 내용은 내 코드를 수정하지 않고 Python의 sys.stdout을 로그 파일에 복제하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!