將sys.stdout 複製到日誌檔案
將sys.stdout 複製到日誌檔案可讓您擷取所有輸出,包括系統呼叫,來自Python 應用程式。儘管很簡單,但當應用程式在互動模式和守護程式模式下運行時,此任務會帶來獨特的挑戰。
互動模式與守護程式模式
在互動模式下,您想要螢幕和日誌檔案接收輸出。但是,在守護程序模式下,所有輸出都應定向到日誌檔案。 os.dup2() 函數非常適合在守護程式模式下重定向輸出,但它沒有提供在互動模式下複製輸出而不修改系統呼叫的直接解決方案。
使用 Tee 進行複製
要解決此問題,您可以使用 Tee 類,它提供了一種將 stdout 複製到日誌檔案的方法。以下是範例:
此類別可讓您建立以日誌檔案名稱和模式為參數的 Tee 實例。 write() 方法將輸出複製到日誌檔案和標準輸出。
實作範例
使用Tee 類別:
在此範例中,所有輸出,包括對「ls -la」的系統調用,都將寫入螢幕和日誌檔案'logfile.txt'。
此解決方案有效記錄所有輸出,包括系統呼叫輸出,而無需修改單一系統呼叫。
以上是如何在互動模式和守護程式模式下將 Python 的 sys.stdout 複製到日誌檔案?的詳細內容。更多資訊請關注PHP中文網其他相關文章!