溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

python中文編碼的問(wèn)題案例及解決方法

發(fā)布時(shí)間:2020-11-06 09:38:46 來(lái)源:億速云 閱讀:157 作者:小新 欄目:編程語(yǔ)言

小編給大家分享一下python中文編碼的問(wèn)題案例及解決方法,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!

我們已經(jīng)介紹了如何用 Python 輸出 "Hello, World!",英文沒(méi)有問(wèn)題,但是如果你輸出中文字符 "你好,世界" 就有可能會(huì)碰到中文編碼問(wèn)題。

Python 文件中如果未指定編碼,在執(zhí)行過(guò)程會(huì)出現(xiàn)報(bào)錯(cuò):

#!/usr/bin/python
print ("你好,世界")

以上程序執(zhí)行輸出結(jié)果為:

  File "test.py", line 2
SyntaxError: Non-ASCII character '\xe4' in file test.py on line 2, but no encoding declared; see http://www.python.org/peps/pep-0263.html for details

Python中默認(rèn)的編碼格式是 ASCII 格式,在沒(méi)修改編碼格式時(shí)無(wú)法正確打印漢字,所以在讀取中文時(shí)會(huì)報(bào)錯(cuò)。

解決方法

只要在文件開頭加入 # -*- coding: UTF-8 -*- 或者 # coding=utf-8 就行了

注意:# coding=utf-8 的 = 號(hào)兩邊不要空格。

實(shí)例(Python 2.0+)

python中文編碼的問(wèn)題案例及解決方法

輸出結(jié)果為:

你好,世界

所以如果大家在學(xué)習(xí)過(guò)程中,代碼中包含中文,就需要在頭部指定編碼。

總結(jié):

1、注意:Python3.X 源碼文件默認(rèn)使用utf-8編碼,所以可以正常解析中文,無(wú)需指定 UTF-8 編碼。

2、注意:如果你使用編輯器,同時(shí)需要設(shè)置 py 文件存儲(chǔ)的格式為 UTF-8,否則會(huì)出現(xiàn)類似以下錯(cuò)誤信息:

SyntaxError: (unicode error) ‘utf-8’ codec can’t decode byte 0xc4 in position 0: invalid continuation byte

Pycharm 設(shè)置步驟:

進(jìn)入 file > Settings,在輸入框搜索 encoding。找到 Editor > File encodings,將 IDE Encoding 和 Project Encoding 設(shè)置為utf-8。

看完了這篇文章,相信你對(duì)python中文編碼的問(wèn)題案例及解決方法有了一定的了解,想了解更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI