我正在嘗試調試我正在編寫的 pythonw 腳本,因為它在通過空閑啟動時可以正常工作,但是在通過 cmd 啟動或雙擊它時會崩潰。我目前失敗的代碼是import syssys.stdout = open("mylog.txt", "w")sys.stderr = open("errors.txt", "w")print("hello world")import thisisgonnafailprint(sys.executable)它確實創建了文件,正如記事本 ++ 告訴我文件已更新,但文件都始終為空,即使它們應該具有設置為失敗的導入的錯誤消息,以及打印行
1 回答

胡說叔叔
TA貢獻1804條經驗 獲得超8個贊
您上面發布的代碼應該可以工作。您遇到的問題很可能是在流仍然打開時檢查文件。使用時,open()您總是需要以某種方式關閉流。在您執行此操作之前,通過其他方法(例如手動打開文件)檢查文件時,您將看不到文件的更改。
在這個例子中,您可以通過重新分配做到這一點無論是sys.stdout和sys.stderr或通過調用close()(首選方法,因為它是更加明確和處理流預期的方式),對他們這樣的:sys.stdout.close()。
另外,請注意,如果您要多次打開和關閉它們,最好使用"a"追加到文件中,而不是一直重寫內容。
編輯:您在評論中詢問以這種方式做事時處理錯誤。您建議的方法是正確的,您可以try/except部分代碼并except關閉流。
import sys
sys.stderr = open("e.txt", "a")
try:
import nonexistingmodule
print 'Should not be printed out'
except:
print 'Should be printed out'
sys.stderr.close()
上面的這段代碼可以讓您測試是否觸發了 except 路徑。
添加回答
舉報
0/150
提交
取消