Maison >développement back-end >Tutoriel Python >Comment puis-je surveiller et enregistrer la sortie des sous-processus en temps réel en Python ?
Surveillance de la sortie en direct des commandes de sous-processus
En Python, subprocess.Popen vous permet d'exécuter des sous-processus tout en contrôlant leurs entrées et sorties. Par défaut, Popen capture à la fois stdout et stderr dans un tampon accessible ultérieurement. Cependant, cela peut s'avérer insuffisant pour surveiller en temps réel la progression du sous-processus.
Stockage simultané des sorties et diffusion en direct
Pour stocker simultanément la sortie pour la journalisation et fournir un diffusion en direct, plusieurs approches peuvent être utilisées :
Basé sur des fichiers Approche
Créez un objet fichier pour la journalisation, transmettez-le à l'argument stdout de Popen et ouvrez le même fichier pour le lire en mode non bloquant. Vous pouvez surveiller le contenu du fichier en boucle, en l'écrivant à la fois dans la console et dans le fichier journal. Cela vous permet de récupérer la sortie de manière incrémentielle.
with io.open("test.log", "wb") as writer, io.open("test.log", "rb", 1) as reader: process = subprocess.Popen(command, stdout=writer) while process.poll() is None: sys.stdout.write(reader.read()) time.sleep(0.5) # Read the remaining sys.stdout.write(reader.read())
Approche basée sur l'itérateur
Créez un itérateur à partir de la sortie standard de Popen et utilisez-le pour lire et écrire en continu sur le sortie standard et un fichier journal. Cette approche convient lorsque vous travaillez avec des flux d'octets pour la sortie standard et le fichier journal.
import subprocess import sys with open("test.log", "wb") as f: process = subprocess.Popen(your_command, stdout=subprocess.PIPE) # replace "" with b"" for Python 3 for c in iter(lambda: process.stdout.read(1), ""): sys.stdout.buffer.write(c) f.buffer.write(c)
Remarque : Ces approches nécessitent une gestion explicite des données binaires si nécessaire. Pour Python 3, remplacez "" par b"" et "w" par "wb" dans les instructions ouvertes.
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!