i-am-sailing

最近,在终端启动Python时,报了一个错误:

  1 Failed calling sys.__interactivehook__
  2 Traceback (most recent call last):
  3   File "d:\ProgramData\Anaconda3\lib\site.py", line 439, in register_readline
  4     readline.read_history_file(history)
  5   File "d:\ProgramData\Anaconda3\lib\site-packages\pyreadline\rlmain.py", line 165, in read_history_file
  6     self.mode._history.read_history_file(filename)
  7   File "d:\ProgramData\Anaconda3\lib\site-packages\pyreadline\lineeditor\history.py", line 82, in read_history_file
  8     for line in open(filename, \'r\'):
  9 UnicodeDecodeError: \'gbk\' codec can\'t decode byte 0xa7 in position 2167: illegal multibyte sequence

原因是Python的终端历史文件中包含中文,但不能正确使用gbk解码。查看了Python历史文件(系统用户目录下的.python_history),其编码方式为“utf-8”,而”history.py”中读取历史文件时使用的编码方式为“gbk”,所以会报错。

 

解决方法

在history.py中使用`for line in open(filename, \'r\')`来打开文件并读取每一行,使用的是默认的编码方式。需要根据不同文件的编码方式传入相应的参数值。

1. 首先检测出要打开的文件的编码方式。

在类中定义一个私有方法_get_encoding,作用是检测文件的编码方式,并返回。(需要导入chardet包)

  1     def _get_encoding(self, filename=None):
  2     	if filename is None:
  3     		return
  4 
  5     	with open(filename, \'rb\') as f:
  6     		return chardet.detect(f.read())[\'encoding\']

2. 修改历史文件内容的读取

  1             
encoding = self._get_encoding(filename)
  2             
for line in open(filename, \'r\', encoding=encoding):
  3                 self.add_history(lineobj.ReadLineTextBuffer(ensure_unicode(line.rstrip())))
  4 

OK。问题解决。

分类:

技术点:

相关文章:

  • 2021-11-04
  • 2021-09-03
  • 2022-01-15
  • 2022-12-23
  • 2021-11-20
  • 2022-12-23
  • 2021-07-12
  • 2021-07-14
猜你喜欢
  • 2021-12-16
  • 2021-12-24
  • 2021-04-12
  • 2022-12-23
  • 2022-01-23
  • 2022-12-23
  • 2021-06-03
相关资源
相似解决方案