Maison >développement back-end >Tutoriel Python >Comment puis-je dupliquer le sys.stdout de Python dans un fichier journal sans modifier mon code ?

Comment puis-je dupliquer le sys.stdout de Python dans un fichier journal sans modifier mon code ?

Linda Hamilton
Linda Hamiltonoriginal
2024-12-03 10:04:09171parcourir

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

Dupliquer sys.stdout dans un fichier journal

En Python, la duplication de sys.stdout dans un fichier journal peut fournir une solution non invasive pour se connecter sans modifier le code de l'application. Voici comment procéder :

En mode interactif, lorsque vous souhaitez que la sortie soit à la fois affichée à l'écran et écrite dans un fichier journal, vous pouvez inverser la logique utilisée en mode démon. Au lieu de rediriger stdout et stderr, dupliquez-les à l'aide de os.dup2.

Le code ci-dessous le démontre :

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())

Cette approche vous permet de consigner toutes les sorties, y compris les sorties des appels système, sans changer le code.

Vous pouvez également exploiter la classe Tee à partir du fichier fourni extrait :

# Initialize a Tee object, redirecting stdout to a log file
tee = Tee("a.log", 'w')

Cette classe garantit que toutes les sorties sont écrites à la fois dans le fichier journal et dans la sortie standard, ce qui en fait une solution pratique pour se connecter en mode interactif sans modifier le code de l'application.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn