파일을 열 때 Python에서 \'UnicodeDecodeError: \'utf-8\' 코덱이 바이트 0xff...\'를 디코딩할 수 없음 오류가 발생하는 이유는 무엇입니까?

Patricia Arquette
풀어 주다: 2024-11-03 21:07:29
원래의
745명이 탐색했습니다.

Why Does Python Throw a

문제 해결: Python Tools/Process.py에서 "UnicodeDecodeError: 'utf-8' 코덱이 바이트 0xff를 디코딩할 수 없습니다..."

pix2pix-tensorflow 저장소에서 "process.py"를 컴파일하는 동안 Python은 "UnicodeDecodeError: 'utf-8' 코덱이 0 위치의 바이트 0xff를 디코딩할 수 없습니다: 잘못된 시작 바이트입니다."라는 오류를 발생시킵니다. 오류를 추적하면 "process.py"의 113행을 가리킵니다:

<code class="python">contents = open(path).read()</code>
로그인 후 복사

오류 이해:

Python은 다음을 나타내는 바이트 배열을 디코딩하려고 시도합니다. UTF-8로 인코딩된 문자열을 유니코드 문자열로 변환합니다. 이 디코딩 프로세스 중에 바이트 배열의 시작 부분에서 잘못된 바이트 시퀀스 "0xff"를 발견합니다. 이 바이트 시퀀스는 UTF-8 인코딩에서 허용되지 않으므로 오류가 발생합니다.

가능한 원인:

open() 함수에 제공된 경로에 이진 데이터가 포함되었을 수 있습니다. UTF-8로 인코딩되지 않았습니다. 이는 Python이 텍스트 데이터를 예상하고 텍스트가 아닌 문자를 발견하여 디코딩 실패로 이어진다는 것을 의미합니다.

해결책:

오류를 해결하려면 다음을 처리해야 합니다. 바이너리 모드의 파일입니다. 이는 Python이 이진 데이터를 텍스트로 디코딩하려고 시도하는 것을 방지합니다. 이를 수행하는 방법은 다음과 같습니다.

<code class="python">with open(path, 'rb') as f:
  contents = f.read()</code>
로그인 후 복사

open() 모드에 'b'를 추가하면 파일이 바이너리로 처리되고 내용을 텍스트로 디코딩하려고 시도하는 대신 바이트로 읽혀집니다. 이렇게 하면 UnicodeDecodeError가 해결됩니다.

위 내용은 파일을 열 때 Python에서 \'UnicodeDecodeError: \'utf-8\' 코덱이 바이트 0xff...\'를 디코딩할 수 없음 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿