Maison >développement back-end >Tutoriel Python >Comment puis-je dupliquer le sys.stdout de Python dans un fichier journal sans modifier mon 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!