佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 解決python2中unicode()函數(shù)在python3中報錯的問題

解決python2中unicode()函數(shù)在python3中報錯的問題

熱門標簽:硅谷的囚徒呼叫中心 企業(yè)做大做強 呼叫中心市場需求 語音系統(tǒng) 客戶服務 電話運營中心 百度AI接口 Win7旗艦版

python2中的unicode()函數(shù)在python3中會報錯:

NameError: name 'unicode' is not defined

There is no such name in Python 3, no. You are trying to run Python 2 code in Python 3. In Python 3, unicode has been renamed to str.

翻譯過來就是:Python 3中沒有這樣的名字,沒有。 您正在嘗試在Python 3中運行Python 2代碼。在Python 3中,unicode已重命名為str。

函數(shù)轉換:unicode()到 str()為:

//python2:
unicode(nn,'utf-8')
//python3:
str(nn)

補充:根本解決Python2中unicode編碼問題

Python2中編碼問題

因為計算機只識別01這要的二進制,所以在計算機存儲我們的文件時,要使用二進制數(shù)來表示。所以編碼就是哪個二進制數(shù)表示哪個字符:

編碼原由系統(tǒng)編碼、文件編碼與python系統(tǒng)編碼Python字符編碼python中的字典、數(shù)組轉字符串中的中文編碼

編碼原由

ASCII編碼

最早出現(xiàn)的是ASCII碼,使用8位二進制數(shù)組合表示128種字符。因為ASCII編碼是美國人發(fā)明的,當初沒考慮給別的國家用,所以,它僅僅表示了所有美式英語的語言字符。但是沒有使用完。

ISO 8859-1/windows-1252

128位字符滿足了美國人的需求,但是隨之歐洲人加入互聯(lián)網(wǎng),為了滿足歐洲人的需求,8位二進制后面還有128位。這一段編碼我們稱之擴展字符集,即ISO 8859-1編碼標準,后來歐洲的需求變更,即規(guī)定了windows-1252代替了ISO 8859-1

GB2312

然后當我國加入后,8位二進制(即一個字節(jié))用完了,于是我們保留ASCII編碼即前128位,后面的全部刪除。因為我國得語言博大精深,所以需要2個字節(jié),即16位才能滿足我們得需求,所以當計算機遇到大于127的字節(jié)時,就一次性讀取兩個字節(jié),將他解碼成漢字。即GB2312編碼

GBK

相當于GB2312的改進版,增添了中文字符。但還是2個字節(jié)表示漢字

GB18030

為了滿足日韓和我國的少數(shù)民族的需求,對GBK的改進,使用變長編碼,要么使用兩個字節(jié),要么使用四個字節(jié)。

Unicode

雖然每種編碼都兼容ASCII編碼,但是各個國家是不兼容的。于是出現(xiàn)了Unicode,它將所有的編碼進行了統(tǒng)一。它不能算是一種具體的編碼標準,只是將全世界的字符進行了編號,并沒有指定他們具體在計算機種以什么樣的形式存儲。

它的具體實現(xiàn)有UTF-8,UTF-16,UTF-32等。

系統(tǒng)編碼、文件編碼與python系統(tǒng)編碼

在linux中獲取系統(tǒng)編碼結果:

Windows系統(tǒng)的編碼,代碼頁936表示GBK編碼

可以看到linux系統(tǒng)默認使用UTF-8編碼,windows默認使用GBK編碼。Linux環(huán)境下,文件默認使用UTF-8編碼。當然你也可以指定文件編碼方式。

Python解釋器內部默認使用的ASCII編碼方式去解讀python源文件。

所以當文件內存在非ASCII字符時,python解釋器無 法識別,就會出現(xiàn)編碼錯誤。

So,這個時候需要告訴python解釋器用utf-8去解讀python源文件

Python字符編碼

Python2中有兩類字符串,分別是str與unicode。這兩類字符串都派生自抽象類basestring。 Str即普通字符串類型

在字符串前加上u即unicode編碼

在代碼中通常用到的是unicode,文件保存的是utf-8編碼。Unicode編碼是固定2個字節(jié)代表一個字符。Utf-8是對英文只用一個字節(jié),對中文是3個字節(jié)。所以unicode運行效率高,utf-8運行效率相比要低,但是空間存儲要小。

Python中str與unicode轉換

Unicode轉str

str轉unicode

其函數(shù)中參數(shù)UTF-8是,以utf-8編碼對unicode對象解碼,或編碼。

python中的字典、數(shù)組轉字符串中的中文編碼

當字典中的中文字符是unicode類型時

decode(“unicode-escape”)相當是反向編碼.然后再進行utf-8編碼即可

當字典中的字符串是string類型時

name = {"name": "中國"}
name = str(name)
print name.decode("string-escape")

當數(shù)組進行字符串化時

最后總結

不管是數(shù)組還是字典,在進行字符串轉換是,即是又一次編碼,所以,對于本身還有的中文字符串又一次編碼,所以要進行一次反編碼,才能看到原有的編碼。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • python中的內置函數(shù)max()和min()及mas()函數(shù)的高級用法
  • python print()函數(shù)的end參數(shù)和sep參數(shù)的用法說明
  • python處理emoji表情(兩個函數(shù)解決兩者之間的聯(lián)系)
  • python繪圖subplots函數(shù)使用模板的示例代碼
  • python-opencv中的cv2.inRange函數(shù)用法說明
  • Python input()函數(shù)用法大全
  • python Pool常用函數(shù)用法總結
  • python 如何用map()函數(shù)創(chuàng)建多線程任務
  • Python函數(shù)參數(shù)中的*與**運算符
  • 詳解python函數(shù)傳參傳遞dict/list/set等類型的問題
  • Python3去除頭尾指定字符的函數(shù)strip()、lstrip()、rstrip()用法詳解
  • Python進階之高級用法詳細總結

標簽:長沙 崇左 山西 海南 濟南 喀什 安康 山西

巨人網(wǎng)絡通訊聲明:本文標題《解決python2中unicode()函數(shù)在python3中報錯的問題》,本文關鍵詞  ;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    盐池县| 乐山市| 军事| 海丰县| 普定县| 北安市| 开阳县| 恩平市| 海南省| 靖西县| 通化县| 和林格尔县| 沿河| 金山区| 梁河县| 曲麻莱县| 临夏市| 威信县| 扎兰屯市| 临泽县| 垦利县| 印江| 西和县| 喀什市| 高台县| 楚雄市| 武安市| 河间市| 铁岭县| 广元市| 武隆县| 拉孜县| 丹棱县| 芦山县| 大竹县| 成安县| 民县| 黔南| 龙州县| 富源县| 万山特区|