Bagaimana untuk Mengalihkan Output Proses Kanak-kanak ke Fail dan Terminal Secara serentak dalam Python?

Patricia Arquette
Lepaskan: 2024-11-03 19:31:03
asal
906 orang telah melayarinya

How to Redirect Child Process Output to Files and Terminal Simultaneously in Python?

Cara Mengoutputkan Keputusan Proses Kanak-kanak ke Fail dan Terminal Serentak dalam Python

Apabila menggunakan subprocess.call(), adalah mungkin untuk menentukan deskriptor fail sebagai outf dan errf untuk mengubah hala stdout dan stderr ke fail tertentu. Walau bagaimanapun, keputusan ini tidak akan dipaparkan secara serentak di terminal.

Penyelesaian Menggunakan Popen dan Threading:

Untuk mengatasinya, kami boleh memanfaatkan Popen secara langsung dan menggunakan stdout=Hujah PAIP untuk membaca daripada stdout proses anak. Begini caranya:

<code class="python">import subprocess
from threading import Thread

def tee(infile, *files):
    # Forward output from `infile` to `files` in a separate thread
    def fanout(infile, *files):
        for line in iter(infile.readline, ""):
            for f in files:
                f.write(line)

    t = Thread(target=fanout, args=(infile,) + files)
    t.daemon = True
    t.start()
    return t

def teed_call(cmd_args, **kwargs):
    # Override `stdout` and `stderr` arguments with PIPE to capture standard outputs
    stdout, stderr = [kwargs.pop(s, None) for s in ["stdout", "stderr"]]
    p = subprocess.Popen(
        cmd_args,
        stdout=subprocess.PIPE if stdout is not None else None,
        stderr=subprocess.PIPE if stderr is not None else None,
        **kwargs
    )
    
    # Create threads to simultaneously write to files and terminal
    threads = []
    if stdout is not None:
        threads.append(tee(p.stdout, stdout, sys.stdout))
    if stderr is not None:
        threads.append(tee(p.stderr, stderr, sys.stderr))
        
    # Join the threads to ensure IO completion before proceeding
    for t in threads:
        t.join()

    return p.wait()</code>
Salin selepas log masuk

Menggunakan fungsi ini, kita boleh melaksanakan proses anak dan menulis outputnya pada kedua-dua fail dan terminal pada masa yang sama:

<code class="python">outf, errf = open("out.txt", "wb"), open("err.txt", "wb")
teed_call(["cat", __file__], stdout=None, stderr=errf)
teed_call(["echo", "abc"], stdout=outf, stderr=errf, bufsize=0)
teed_call(["gcc", "a b"], close_fds=True, stdout=outf, stderr=errf)</code>
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimana untuk Mengalihkan Output Proses Kanak-kanak ke Fail dan Terminal Secara serentak dalam Python?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan