터미널에서 Python 타임즈 오류 해결 방안을 시작합니다.
Failed calling sys.__interactivehook__
Traceback (most recent call last):
File "d:\ProgramData\Anaconda3\lib\site.py", line 439, in register_readline
readline.read_history_file(history)
File "d:\ProgramData\Anaconda3\lib\site-packages\pyreadline\rlmain.py", line 165, in read_history_file
self.mode._history.read_history_file(filename)
File "d:\ProgramData\Anaconda3\lib\site-packages\pyreadline\lineeditor\history.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
파이썬의 터미널 역사 파일에 중국어가 포함되어 있지만 gbk 디코딩을 정확하게 사용할 수 없기 때문이다.Python 히스토리 파일 (시스템 사용자 디렉터리의.python_history) 을 보았습니다. "utf-8"과 "history"인코딩 방식입니다.py에서 역사 파일을 읽을 때 사용하는 인코딩 방식은 "gbk"이기 때문에 오류가 발생합니다. 해결 방법
역사에서.py에서'for line in open (filename,'r') 을 사용하여 파일을 열고 줄을 읽습니다. 기본 인코딩 방식을 사용합니다.서로 다른 파일의 인코딩 방식에 따라 상응하는 매개 변수 값을 전달해야 한다.
1. 먼저 열 파일의 인코딩 방식을 검출합니다.
클래스에서 개인 방법을 정의합니다_get_인코딩은 파일의 인코딩 방식을 검사하고 되돌려주는 역할을 합니다.(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. 히스토리 파일 내용 읽기 수정
encoding = self._get_encoding(filename)
for line in open(filename, 'r', encoding=encoding):
self.add_history(lineobj.ReadLineTextBuff(ensure_unicode(line.rstrip())))
이상은 단말기에서 Python 타임즈 오류를 시작하는 해결 방안의 상세한 내용입니다. 단말기에서 Python 오류를 신고하는 것에 대한 더 많은 자료는 저희 다른 관련 글을 주목해 주십시오!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
로마 숫자를 정수로 또는 그 반대로 변환그 중 하나는 로마 숫자를 정수로 변환하는 함수를 만드는 것이었고 두 번째는 그 반대를 수행하는 함수를 만드는 것이었습니다. 문자만 포함합니다'I', 'V', 'X', 'L', 'C', 'D', 'M' ; 문자열이 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.