Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimanakah Saya Boleh Menduakan sys.stdout Python kepada Fail Log dalam Kedua-dua Mod Interaktif dan Daemon?
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!