Maison >développement back-end >Tutoriel Python >Comment puis-je surveiller et enregistrer la sortie des sous-processus en temps réel en Python ?

Comment puis-je surveiller et enregistrer la sortie des sous-processus en temps réel en Python ?

Patricia Arquette
Patricia Arquetteoriginal
2024-12-05 04:17:10606parcourir

How Can I Monitor and Log Subprocess Output in Real-Time in 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!

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