백엔드 개발 파이썬 튜토리얼 Python의 문자 인코딩에 대한 자세한 설명

Python의 문자 인코딩에 대한 자세한 설명

Jun 16, 2017 am 10:49 AM
python 문자 인코딩

다음 편집기는 Python의 기본 문자 인코딩에 대한 기사를 제공합니다. 에디터가 꽤 좋다고 생각해서 지금 공유해서 참고용으로 올려보겠습니다. 에디터를 따라가서 함께 살펴볼까요

서문

문자 인코딩은 문제가 발생하기 매우 쉽습니다. 몇 가지 단어를 염두에 두어야 합니다.

1. 어떤 인코딩을 사용해야 하는지 Open

2. 프로그램 실행은 먼저 파일을 메모리로 읽어들이는 것입니다

3. 유니코드는 상위 인코딩이며 다른 인코딩 형식으로만 인코딩되고 디코딩될 수 있습니다

utf- 8, GBK 이것은 하위 8 인코딩이며 디코딩만 가능합니다 유니코드로 인코딩

1. 문자 인코딩이란

우리는 컴퓨터가 바이너리만 인식할 수 있고 우리가 일반적으로 작성하는 코드는 변환이 필요하다는 것을 알고 있습니다. 컴퓨터가 인식할 수 있도록 바이너리로 변환합니다. 그렇다면 우리가 쓰는 문자를 바이너리로 어떻게 변환합니까? 이 프로세스는 실제로 우리가 쓰는 문자를 특정 숫자에 일대일로 대응시키는 표준을 사용합니다. 이 표준을 문자 인코딩이라고 합니다.

문자------(문자 인코딩)--------->숫자

2. 문자 인코딩의 개발 역사

1. ASCII 코드

컴퓨터에서 유래 미국에서는 문자 인코딩도 미국에서 시작되었습니다. 그러나 미국인이 사용하는 문자에는 26개의 문자와 일부 특수 기호만 있습니다. 중국과 달리 초등학생들은 수천 개의 한자를 알아야 한다. 따라서 미국 사람들은 문자 인코딩으로 ASCII 코드(American Standard Code for Information Interchange)를 사용합니다. 1Bytes=8bit는 2의 8승이 가능하며, 이는 256개의 서로 다른 변경 사항입니다. 비트, 즉 127자를 사용했는데 이는 미국 국민에게는 충분합니다(물론 비용상의 이유로). 나중에 라틴어가 8위로 편성되어 이제 아스키 코드가 꽉 차서 영어권 국가들과 라틴 국가들이 즐겁게 놀 수 있게 되었습니다.

2.GBK

중국의 현재 기술은 미제국만큼 좋지는 않지만 긍정적인 마음을 가지고 있습니다. 그래서 1980년 국가표준국에서 중국어에 사용되는 문자 인코딩을 발행했습니다. GBK는 한자를 나타내기 위해 2바이트를 사용하므로 2의 16승, 즉 65536개의 조합이 있어 한자에 충분합니다.

동시에 다른 나라에서도 일본의 Shift_JIS, 한국의 Euc-kr 등 자체 국가 문자 인코딩 표준을 발표했습니다.

3. 유니코드

수백 개가 있었다고 합니다. 전성기의 문자 인코딩은 서로를 지원하지 않으며 모든 국가의 사람들이 매우 백본적인 것처럼 보이지만 이는 세계의 상호 운용성에 도움이 되지 않으므로 유니코드가 탄생했습니다. 1994년 국제표준화기구(International Organization for Standardization)는 2바이트를 사용하여 문자를 표현하고 65,536개의 조합을 갖는 유니버설 코드(Universal Code)로 알려진 유니코드를 출시했는데, 이는 이미 전 세계 대부분의 언어를 포괄할 수 있습니다.

4.utf-8

유니코드도 좋지만, 원래 1바이트로 표현할 수 있었던 영어가 이제는 2바이트를 사용해야 하므로 저장 공간이 두 배로 늘어나는 것은 당연합니다. 완벽해서 영어 문자에는 1바이트, 중국어에는 3바이트만 사용하는 UTF-8이 만들어졌습니다.

5. 유니코드의 모든 문자는 2바이트이므로 문자를 숫자로 변환하는 것은 빠르지만, utf-8은 다양한 길이를 사용하여 다양한 문자를 나타냅니다. 공간을 절약하지만 변환 효율성은 유니코드만큼 빠르지 않습니다메모리에 사용되는 문자 인코딩은 메모리 속도를 높이기 위한 것이므로 속도를 보장하기 위해 약간의 공간을 희생하는 것이 좋습니다

힘듭니다. 디스크 및 네트워크 전송에서는 utf-8을 사용하는데, 이는 디스크 I/O나 네트워크 I/O 지연 시간이 utf-8의 변환 효율보다 훨씬 크고, 네트워크 전송 시 대역폭을 최대한 절약해야 하기 때문입니다

셋. Python 인터프리터 실행

첫 번째 단계: Python 인터프리터가 시작되면 텍스트 편집기를 시작하는 것과 같습니다. 두 번째 단계: Python 인터프리터는 t.py 파일을 열고 내용을 읽는 텍스트 편집기 역할을 합니다.

세 번째 단계: 파이썬 인터프리터는 방금 메모리에 로드된 t.py의 코드를 해석하고 실행합니다.

두 번째 단계에서는 t.py 파일은 저장될 때 문자 인코딩을 가지고 있으며 Python 인터프리터에서 파일을 열 때 동일한 인코딩 방법도 지정해야 합니다(Python2의 기본 인코딩 방법은 ASCII이고 Python3의 기본 인코딩 방법은 utf-8입니다) 파일 저장의 인코딩 형식이 Python 인터프리터의 기본 인코딩 방법과 다른 경우 파일 시작 부분에 있어야 합니다. #coding을 작성하면 Python 인터프리터가 읽을 때 기본 인코딩 방법을 사용하지 않도록 지시합니다. 하지만 헤더 파일에 지정된 방법을 사용하여 파일을 읽으면 오류가 발생하지 않습니다.

세 번째 단계: 메모리에 로드된 코드(기본적으로 유니코드)를 읽은 후 실행합니다. 실행 중에 변수 정의와 같은 작업이 발생하면 메모리에 새로운 메모리 공간이 열립니다. 이때 새로 열리는 메모리 공간은 반드시 유니코드일 필요는 없습니다. 사용자는 변수 정의 시 인코딩 방법을 지정할 수 있습니다. 정의 시 열리는 메모리 공간은 단지 공간일 뿐이며 어떤 인코딩 형식으로든 코드를 저장할 수 있습니다. Python3을 예로 들어보겠습니다

4. 인코딩 및 디코딩

파일을 저장하는 것은 메모리에 있는 파일을 하드 디스크에 저장하는 것입니다

파일을 읽는 것은 하드 디스크에 있는 파일을 읽는 것입니다. 메모리 속으로

유니코드는 상위 인코딩인 utf-8, GBK이며, 하위 코드를 다른 인코딩으로 변환하려면 먼저 상위 인코딩으로 변환한 후 사용해야 합니다. 상위 인코딩에서 다른 하위 인코딩으로 변환되는 것입니다. 디코딩은 하위 인코딩에서 변환되는 디코딩입니다. 상위 코드가 되는 과정은 유니코드

인코딩은 유니코드를 다른 인코딩으로 변환하는 과정입니다

말씀대로 이전에는 파일을 메모리로 읽을 때 유니코드 인코딩이 됩니다(물론 이는 기본 상황이며 지침에 따라 변경될 수도 있습니다). 하드 디스크에서 파일을 읽는 프로세스는 utf-8을 디코딩하는 것입니다. in the hard disk into Unicode

파일이 저장될 때 메모리에서 하드디스크로 저장하는 과정입니다. 하드디스크의 인코딩 방식은 utf-8이며, 유니코드에서 utf-8로 인코딩해야 합니다. utf -8

5 Python2와 Python3의 차이점1. Python2의 기본 인코딩은 utf-8로 저장된 파일을 열 때 오류가 보고됩니다. : utf-8을 헤더 파일에 추가합니다.

Str은 Python2에서 바이트로 인식되므로 Python2의 str은 실제로 기본적으로 str 앞에 u를 추가하는 작업을 수행합니다. 먼저 유니코드로 변환한 다음 바이트로 인코딩합니다

Python2에는 str과 Unicode라는 두 가지 문자열 유형이 있습니다. str은 앞에 'u'를 추가하여 유니코드로 변환할 수 있습니다. Python 3의 기본 인코딩입니다. utf-8이며, 직접 열고 utf-8에 저장할 수 있습니다. Python3의

str 파일은 유니코드로 인식됩니다

Python3에는 두 가지 문자열 유형(bytes 및 str)도 있지만 bytes는 bytes이고 str은 입니다. unicode

6. 터미널로 인쇄

먼저 Windows 터미널의 기본 인코딩 방식이 GBK라는 것을 알아야 합니다 터미널도 애플리케이션이고 메모리에서 실행되므로 print( )은 기억에서 기억으로이다. 따라서 유니코드의 경우 어떻게 인쇄하든 오류가 발생하지 않습니다. 그러나 Python2에서는 'u'가 포함된 문자열을 제외하고 다른 문자열은 바이트입니다. 이때 터미널에서는 GBK 인코딩을 사용합니다. 지정된 utf-8 또는 기본 Ascii 코드인 경우 터미널에서 인쇄할 때 오류가 발생합니다.

현재 제가 알고 있는 내용입니다. 앞으로 오류나 불분명한 표현이 있다는 것을 알게 되면 수정하겠습니다. 아아, 문자 인코딩은 함정

위 내용은 Python의 문자 인코딩에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

C 언어 합계의 기능은 무엇입니까? C 언어 합계의 기능은 무엇입니까? Apr 03, 2025 pm 02:21 PM

C 언어에는 내장 합계 기능이 없으므로 직접 작성해야합니다. 합계는 배열 및 축적 요소를 가로 질러 달성 할 수 있습니다. 루프 버전 : 루프 및 배열 길이를 사용하여 계산됩니다. 포인터 버전 : 포인터를 사용하여 배열 요소를 가리키며 효율적인 합계는 자체 증가 포인터를 통해 달성됩니다. 동적으로 배열 버전을 할당 : 배열을 동적으로 할당하고 메모리를 직접 관리하여 메모리 누출을 방지하기 위해 할당 된 메모리가 해제되도록합니다.

누가 더 많은 파이썬이나 자바 스크립트를 지불합니까? 누가 더 많은 파이썬이나 자바 스크립트를 지불합니까? Apr 04, 2025 am 12:09 AM

기술 및 산업 요구에 따라 Python 및 JavaScript 개발자에 대한 절대 급여는 없습니다. 1. 파이썬은 데이터 과학 및 기계 학습에서 더 많은 비용을 지불 할 수 있습니다. 2. JavaScript는 프론트 엔드 및 풀 스택 개발에 큰 수요가 있으며 급여도 상당합니다. 3. 영향 요인에는 경험, 지리적 위치, 회사 규모 및 특정 기술이 포함됩니다.

별개의 구별이 관련되어 있습니까? 별개의 구별이 관련되어 있습니까? Apr 03, 2025 pm 10:30 PM

구별되고 구별되는 것은 구별과 관련이 있지만, 다르게 사용됩니다. 뚜렷한 (형용사)는 사물 자체의 독창성을 묘사하고 사물 사이의 차이를 강조하는 데 사용됩니다. 뚜렷한 (동사)는 구별 행동이나 능력을 나타내며 차별 과정을 설명하는 데 사용됩니다. 프로그래밍에서 구별은 종종 중복 제거 작업과 같은 컬렉션에서 요소의 독창성을 나타내는 데 사용됩니다. 홀수 및 짝수 숫자를 구별하는 것과 같은 알고리즘이나 함수의 설계에 별개가 반영됩니다. 최적화 할 때 별도의 작업은 적절한 알고리즘 및 데이터 구조를 선택해야하며, 고유 한 작업은 논리 효율성의 구별을 최적화하고 명확하고 읽을 수있는 코드 작성에주의를 기울여야합니다.

이해하는 방법! x는? 이해하는 방법! x는? Apr 03, 2025 pm 02:33 PM

! x 이해! x는 C 언어로 된 논리적 비 운영자입니다. 그것은 x의 값, 즉 실제 변경, 거짓, 잘못된 변경 사항을 부수합니다. 그러나 C의 진실과 거짓은 부울 유형보다는 숫자 값으로 표시되며, 0이 아닌 것은 참으로 간주되며 0만이 거짓으로 간주됩니다. 따라서! x는 음수를 양수와 동일하게 처리하며 사실로 간주됩니다.

C 언어에서 합계는 무엇을 의미합니까? C 언어에서 합계는 무엇을 의미합니까? Apr 03, 2025 pm 02:36 PM

합에 대한 C에는 내장 합계 기능이 없지만 다음과 같이 구현할 수 있습니다. 루프를 사용하여 요소를 하나씩 축적합니다. 포인터를 사용하여 요소를 하나씩 액세스하고 축적합니다. 큰 데이터 볼륨의 경우 병렬 계산을 고려하십시오.

H5 페이지 생산에는 지속적인 유지 보수가 필요합니까? H5 페이지 생산에는 지속적인 유지 보수가 필요합니까? Apr 05, 2025 pm 11:27 PM

코드 취약점, 브라우저 호환성, 성능 최적화, 보안 업데이트 및 사용자 경험 개선과 같은 요소로 인해 H5 페이지를 지속적으로 유지해야합니다. 효과적인 유지 관리 방법에는 완전한 테스트 시스템 설정, 버전 제어 도구 사용, 페이지 성능을 정기적으로 모니터링하고 사용자 피드백 수집 및 유지 관리 계획을 수립하는 것이 포함됩니다.

58.com 작업 페이지에서 실시간 응용 프로그램 및 뷰어 데이터를 얻는 방법은 무엇입니까? 58.com 작업 페이지에서 실시간 응용 프로그램 및 뷰어 데이터를 얻는 방법은 무엇입니까? Apr 05, 2025 am 08:06 AM

크롤링하는 동안 58.com 작업 페이지의 동적 데이터를 얻는 방법은 무엇입니까? Crawler 도구를 사용하여 58.com의 작업 페이지를 크롤링 할 때는이 문제가 발생할 수 있습니다.

사랑 코드 복사 및 붙여 넣기 복사하여 사랑 코드를 무료로 붙여 넣으십시오. 사랑 코드 복사 및 붙여 넣기 복사하여 사랑 코드를 무료로 붙여 넣으십시오. Apr 04, 2025 am 06:48 AM

코드 복사 및 붙여 넣기는 불가능하지는 않지만주의해서 처리해야합니다. 코드의 환경, 라이브러리, 버전 등과 같은 종속성은 현재 프로젝트와 일치하지 않으므로 오류 또는 예측할 수없는 결과를 초래할 수 있습니다. 파일 경로, 종속 라이브러리 및 Python 버전을 포함하여 컨텍스트가 일관되게 유지하십시오. 또한 특정 라이브러리의 코드를 복사 및 붙여 넣을 때 라이브러리 및 해당 종속성을 설치해야 할 수도 있습니다. 일반적인 오류에는 경로 오류, 버전 충돌 및 일관되지 않은 코드 스타일이 포함됩니다. 성능 최적화는 코드의 원래 목적 및 제약에 따라 재 설계 또는 리팩토링되어야합니다. 복사 코드를 이해하고 디버그하고 맹목적으로 복사하여 붙여 넣지 않는 것이 중요합니다.

See all articles