본 글의 예시는 Windows 명령 창에서 Python 파일을 실행할 때 생성되는 잘못된 코드 문제를 설명합니다.
Ps: 오류가 있으면 수정해 주세요.
# -*- coding:utf-8 -*-str = "彦雪"print str
후. 실행 시 출력되는 결과는 다음과 같습니다.
褰﹂洩
가블링된 코드 결과는 다른 것과 다를 수 있지만 모두 잘못된 코드입니다!!
Python2 기본 인코딩은 "ascii"이고 ascii 인코딩은 그렇지 않습니다. 한자가 포함되어 있습니다
한자가 포함되어 있으면 Python 인터프리터는 일반적으로 오류를 보고합니다.
그러나 UTF-8 인코딩을 지정하면 Python은 더 이상 오류를 보고하지 않습니다.
"# --coding:utf -8 --"는 Python 소스 코드가 UTF-8로 인코딩되도록 지정합니다.
window의 기본 인코딩은 gbk 인코딩이므로 str을 gbk로 인코딩한 후 출력해야 합니다.
Python은 utf-8을 gbk로 직접 변환하는 것을 허용하지 않기 때문에 먼저 utf-8을 유니코드로 변환한 다음 gbk로 변환해야 합니다.
이 방법의 단점은 크로스 플랫폼을 사용할 때 문제가 발생하므로 Python은 유니코드를 출력으로 사용하는 편리한 솔루션을 제공합니다. 이 방법은 raw_input
에는 적용되지 않습니다. 출력을 인쇄해야 할 때 Python은 먼저 문자 출력 프로그램(명령줄 또는 출력 함수)을 호출합니다. 그런 다음 문자열을 문자 출력 프로그램에서 사용하는 인코딩으로 인코딩하면(문자 출력 프로그램이 인코딩을 인식할 수 없기 때문에 문자 왜곡이 발생하지 않도록) 문자 출력 프로그램은 인코딩된 문자를 대상에 출력합니다.
# 方法一 中文前加u, 告诉Python解释器后面的是个unicode编码str = u"彦雪"
# 方法二 str.decode('utf-8') 以utf-8编码对字符串 str 进行解码, 获取unicodestr = "彦雪".decode('utf-8')
# 方法三 unicode(str, 'utf-8') 将字符串 str 以utf-8编码解码, 获取unicodestr = unicode('彦雪','utf-8')
raw_input을 사용하려면 중국어를 시스템 인코딩으로 변환해야 하며 방법은 다음과 같습니다
# 方法1 str.encode("gbk") 将unicode转为gbk 编码content = raw_input(u"输入内容: ".encode("gbk"))
# 方法2content = raw_input("输入内容: ".decode('utf-8').encode("gbk"))
이 작성 방법은 매우 편리하지만 크로스 플랫폼 효과가 좋지 않습니다. 개인적으로 이 작성 방법은 한자와 raw_input을 별도로 작성하는 것이 좋습니다. 다른 수단을 통해
Python 코딩 주석 # -- 코딩:utf-8 --
PEP 263 -- Python 소스 코드 인코딩 정의
Python 인코딩, 잘못된 문자 및 유니코드에 대한 연구
raw_input 입력, 파일 읽기, 변수 비교 등 str , unicode, utf-8 변환 문제
현재 사임했습니다. 기다리는 동안 이전에 자주 겪었던 문제를 공유하고 논의하길 바랍니다. 모두에게 도움이 될 것입니다. 수정을 환영합니다
지식을 공유하고 프로그래밍의 즐거움을 즐기세요
위 내용은 Python2.7은 Windows 명령 창에 중국어 왜곡 문자를 출력합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!