在終端啟動(dòng)Python時(shí)報(bào)錯(cuò)的解決方案
最近,在終端啟動(dòng)Python時(shí),報(bào)了一個(gè)錯(cuò)誤:
Failed calling sys.__interactivehook__Traceback (most recent call last): File 'd:ProgramDataAnaconda3libsite.py', line 439, in register_readline readline.read_history_file(history) File 'd:ProgramDataAnaconda3libsite-packagespyreadlinerlmain.py', line 165, in read_history_file self.mode._history.read_history_file(filename) File 'd:ProgramDataAnaconda3libsite-packagespyreadlinelineeditorhistory.py', line 82, in read_history_file for line in open(filename, ’r’):UnicodeDecodeError: ’gbk’ codec can’t decode byte 0xa7 in position 2167: illegal multibyte sequence
原因是Python的終端歷史文件中包含中文,但不能正確使用gbk解碼。查看了Python歷史文件(系統(tǒng)用戶目錄下的.python_history),其編碼方式為“utf-8”,而”history.py”中讀取歷史文件時(shí)使用的編碼方式為“gbk”,所以會(huì)報(bào)錯(cuò)。
解決方法
在history.py中使用`for line in open(filename, ’r’)`來(lái)打開文件并讀取每一行,使用的是默認(rèn)的編碼方式。需要根據(jù)不同文件的編碼方式傳入相應(yīng)的參數(shù)值。
1. 首先檢測(cè)出要打開的文件的編碼方式。
在類中定義一個(gè)私有方法_get_encoding,作用是檢測(cè)文件的編碼方式,并返回。(需要導(dǎo)入chardet包)
def _get_encoding(self, filename=None): if filename is None: return with open(filename, ’rb’) as f: return chardet.detect(f.read())[’encoding’]
2. 修改歷史文件內(nèi)容的讀取
encoding = self._get_encoding(filename) for line in open(filename, ’r’, encoding=encoding):self.add_history(lineobj.ReadLineTextBuff(ensure_unicode(line.rstrip())))
以上就是在終端啟動(dòng)Python時(shí)報(bào)錯(cuò)的解決方案的詳細(xì)內(nèi)容,更多關(guān)于終端啟動(dòng)python報(bào)錯(cuò)的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. XML入門的常見問(wèn)題(四)2. HTML5 Canvas繪制圖形從入門到精通3. ASP基礎(chǔ)知識(shí)VBScript基本元素講解4. 利用CSS3新特性創(chuàng)建透明邊框三角5. asp(vbscript)中自定義函數(shù)的默認(rèn)參數(shù)實(shí)現(xiàn)代碼6. 使用Spry輕松將XML數(shù)據(jù)顯示到HTML頁(yè)的方法7. 詳解CSS偽元素的妙用單標(biāo)簽之美8. JSP的Cookie在登錄中的使用9. XHTML 1.0:標(biāo)記新的開端10. PHP設(shè)計(jì)模式中工廠模式深入詳解
