대화형 모드와 데몬 모드 모두에서 Python의 sys.stdout을 로그 파일에 어떻게 복제할 수 있습니까?
sys.stdout을 로그 파일에 복제
sys.stdout을 로그 파일에 복제하면 시스템 호출을 포함한 모든 출력을 캡처할 수 있습니다. , Python 애플리케이션에서. 단순함에도 불구하고 이 작업은 애플리케이션이 대화형 모드와 데몬 모드 모두에서 작동할 때 독특한 과제를 제기합니다.
대화형 대 데몬 모드
대화형 모드에서는 다음을 원합니다. 화면과 로그 파일 모두 출력을 수신합니다. 그러나 데몬 모드에서는 모든 출력이 로그 파일로 전달되어야 합니다. os.dup2() 함수는 데몬 모드에서 출력을 리디렉션하는 데 적합하지만 시스템 호출을 수정하지 않고 대화형 모드에서 출력을 복제하는 간단한 솔루션을 제공하지 않습니다.
Tee를 사용한 복제
이 문제를 극복하려면 stdout을 로그 파일에 복제하는 방법을 제공하는 Tee 클래스를 사용할 수 있습니다. 예는 다음과 같습니다.
class Tee(object): def __init__(self, name, mode): self.file = open(name, mode) self.stdout = sys.stdout sys.stdout = self def __del__(self): sys.stdout = self.stdout self.file.close() def write(self, data): self.file.write(data) self.stdout.write(data) def flush(self): self.file.flush()
이 클래스를 사용하면 로그 파일 이름과 모드를 매개변수로 사용하는 Tee 인스턴스를 생성할 수 있습니다. write() 메소드는 로그 파일과 stdout 모두에 출력을 복제합니다.
구현 예
Tee 클래스를 사용하려면:
with Tee('logfile.txt', 'w') as tee: print('Hello world!') os.system('ls -la')
이 예에서는 'ls -la'에 대한 시스템 호출을 포함한 모든 출력이 화면과 로그 파일 모두에 기록됩니다. 'logfile.txt'.
이 솔루션은 개별 시스템 호출을 수정할 필요 없이 시스템 호출 출력을 포함한 모든 출력을 효과적으로 기록합니다.
위 내용은 대화형 모드와 데몬 모드 모두에서 Python의 sys.stdout을 로그 파일에 어떻게 복제할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

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

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

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

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

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

뜨거운 주제











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

Linux 터미널에서 Python 사용 ...

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

Pythonasyncio에 대해 ...

Investing.com의 크롤링 전략 이해 많은 사람들이 종종 Investing.com (https://cn.investing.com/news/latest-news)에서 뉴스 데이터를 크롤링하려고합니다.

Python 3.6에 피클 파일 로딩 3.6 환경 오류 : ModulenotFounderRor : nomodulename ...

SCAPY 크롤러를 사용할 때 파이프 라인 파일을 작성할 수없는 이유에 대한 논의 지속적인 데이터 저장을 위해 SCAPY 크롤러를 사용할 때 파이프 라인 파일이 발생할 수 있습니다 ...
