疑難排解:Python Tools/Process.py 中的「UnicodeDecodeError: 'utf-8' 編解碼器無法解碼字節0xff...」
從pix2pix-tensorflow 儲存庫編譯「process.py」時,Python 會引發錯誤「UnicodeDecodeError:'utf-8'編解碼器無法解碼位置0 中的位元組0xff:無效的起始位元組。陣列將UTF-8 編碼的字串轉換為Unicode 字串。在此解碼過程中,它在位元組數組的開頭遇到無效位元組序列“0xff”。 UTF-8 編碼中不允許使用此位元組序列,從而導致錯誤。
<code class="python">contents = open(path).read()</code>
可能原因:
提供給 open() 函數的路徑可能包含二進位資料不是 UTF-8 編碼的。這意味著Python期望文本數據,遇到非文字字符,導致解碼失敗。解決方案:
要解決該錯誤,需要處理二進位模式的檔案。這可以防止 Python 嘗試將二進位資料解碼為文字。操作方法如下:透過在 open() 模式中添加 'b',檔案將被視為二進制,並且內容將作為字節讀取,而不是嘗試將其解碼為文字。這應該可以解決 UnicodeDecodeError。
以上是為什麼 Python 開啟檔案時會拋出「UnicodeDecodeError: \'utf-8\' codec can\t Decode byte 0xff...\」錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!