Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimanakah Saya Boleh Menduakan sys.stdout Python kepada Fail Log dalam Kedua-dua Mod Interaktif dan Daemon?

Bagaimanakah Saya Boleh Menduakan sys.stdout Python kepada Fail Log dalam Kedua-dua Mod Interaktif dan Daemon?

Linda Hamilton
Linda Hamiltonasal
2024-12-01 12:23:11789semak imbas

How Can I Duplicate Python's sys.stdout to a Log File in Both Interactive and Daemon Modes?

Pendua sys.stdout ke Fail Log

Penduaan sys.stdout ke fail log membolehkan anda menangkap semua output, termasuk panggilan sistem , daripada aplikasi Python. Walaupun mudah, tugas ini menimbulkan cabaran unik apabila aplikasi beroperasi dalam kedua-dua mod interaktif dan daemon.

Mod Interaktif lwn Daemon

Dalam mod interaktif, anda mahu kedua-dua skrin dan fail log untuk menerima output. Walau bagaimanapun, dalam mod daemon, semua output harus diarahkan ke fail log. Fungsi os.dup2() berfungsi dengan baik untuk mengubah hala keluaran dalam mod daemon, tetapi ia tidak menyediakan penyelesaian yang mudah untuk menduplikasi output dalam mod interaktif tanpa mengubah suai panggilan sistem.

Penduaan Menggunakan Tee

Untuk mengatasi isu ini, anda boleh menggunakan kelas Tee, yang menyediakan cara untuk menduplikasi stdout kepada fail log. Berikut ialah contoh:

class Tee(object):
    def __init__(self, name, mode):
        self.file = open(name, mode)
        self.stdout = sys.stdout
        sys.stdout = self
    def __del__(self):
        sys.stdout = self.stdout
        self.file.close()
    def write(self, data):
        self.file.write(data)
        self.stdout.write(data)
    def flush(self):
        self.file.flush()

Kelas ini membolehkan anda mencipta tika Tee yang menggunakan nama fail log dan mod sebagai parameter. Kaedah write() menduplikasi output kepada kedua-dua fail log dan stdout.

Contoh Pelaksanaan

Untuk menggunakan kelas Tee:

with Tee('logfile.txt', 'w') as tee:
    print('Hello world!')
    os.system('ls -la')

Dalam contoh ini, semua output, termasuk panggilan sistem ke 'ls -la', akan ditulis pada kedua-dua skrin dan fail log 'logfile.txt'.

Penyelesaian ini merekodkan semua output dengan berkesan, termasuk output panggilan sistem, tanpa perlu mengubah suai panggilan sistem individu.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menduakan sys.stdout Python kepada Fail Log dalam Kedua-dua Mod Interaktif dan Daemon?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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