텍스트 파일에 저장된 데이터를 조작하려고 시도하는 중 다음 오류가 발생했습니다.
Traceback (most recent call last): File "SCRIPT LOCATION", line NUMBER, in <module> text = file.read() File "C:\Python31\lib\encodings\cp1252.py", line 23, in decode return codecs.charmap_decode(input,self.errors,decoding_table)[0] UnicodeDecodeError: 'charmap' codec can't decode byte 0x90 in position 2907500: character maps to `<undefined>`
이 오류는 가정된 인코딩(CP1252)과 파일의 실제 인코딩이 일치하지 않기 때문에 발생합니다. 이 문제를 해결하려면 올바른 인코딩을 식별하고 파일을 열 때 이를 명시적으로 지정해야 합니다.
파일 인코딩 식별
질문에 명시된 대로 파일 인코딩이 중요합니다. 안타깝게도 이 작업은 수동으로 수행해야 합니다. 일반적인 인코딩에는 Latin-1 및 UTF-8이 포함됩니다. 그러나 0x90이 Latin-1에서 유효한 문자가 아니라는 점을 고려하면 UTF-8이 강력한 후보입니다.
인코딩 지정
인코딩을 결정한 후에는 , 인코딩 매개변수를 사용하여 파일을 열 때 이를 지정할 수 있습니다.
file = open(filename, encoding="utf8")
올바른 인코딩을 제공함으로써 Python 텍스트 파일을 적절하게 디코딩할 수 있으며 'UnicodeDecodeError' 예외가 발생하지 않고 해당 내용을 조작할 수 있습니다.
위 내용은 Python에서 텍스트 파일을 읽을 때 'UnicodeDecodeError'를 수정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!