Maison >développement back-end >Tutoriel Python >Comment puis-je afficher simultanément la sortie du programme sur la console et la consigner dans un fichier ?

Comment puis-je afficher simultanément la sortie du programme sur la console et la consigner dans un fichier ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-12-22 04:45:09188parcourir

How Can I Simultaneously Display Program Output to the Console and Log It to a File?

Sortie du système Teeing dans un fichier journal

Problème :

Comment afficher simultanément la sortie sur la console tout en enregistrant dans un fichier, y compris l'appel système sortie ?

Solution :

Utilisez la classe Tee pour dupliquer la sortie système dans un fichier journal sans redirection.

Tout d'abord, importez les bibliothèques nécessaires :

import sys

Ensuite, instanciez un objet Tee :

tee = Tee("my_log.txt", 'w')

Cela ouvrira le fichier journal spécifié et dupliquez toutes les sorties stdout ultérieures dans le fichier et la console.

Enfin, assurez-vous de rétablir la sortie stdout à son état d'origine une fois terminé :

del tee

Exemple d'utilisation :

with Tee("my_log.txt", 'w'):
    print("foo bar")
    os.spawnve("P_WAIT", "/bin/ls", ["/bin/ls"], {})
    os.execve("/bin/ls", ["/bin/ls"], os.environ)

Ce code imprimera "foo bar" sur la console et l'enregistrera dans "my_log.txt", ainsi que toute sortie du commandes système exécutées.

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