>백엔드 개발 >파이썬 튜토리얼 >내 코드를 수정하지 않고 Python의 sys.stdout을 로그 파일에 복제하려면 어떻게 해야 합니까?

내 코드를 수정하지 않고 Python의 sys.stdout을 로그 파일에 복제하려면 어떻게 해야 합니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-03 10:04:09171검색

How Can I Duplicate Python's sys.stdout to a Log File Without Modifying My Code?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.