91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python2 中 unicode 和 str 之間的轉換及與python3 str 的區別

發布時間:2020-10-16 12:39:35 來源:腳本之家 閱讀:309 作者:lowmanisbusy 欄目:開發技術

在python2中字符串分為 unicode 和 str 類型

  Str To Unicode 使用decode(), 解碼
  Unicode To Str 使用encode(), 編碼

返回數據給前端時需要先將unicode轉換為str類型, 事實上, python2 中的 str 就是一串字節(byte), 而網絡通信時, 傳輸的就是字節. 如果前端需要接收json數據, 需要使用 json.dumps() 將數據轉換為json格式進行返回, 當數據是嵌套類型的數據, 內層的數據可能無法直接轉換為str類型的數據, 這時可以使用eval()函數進行轉換, 再使用json.dumps()進行轉換為json格式的數據, json 事實上就是一串字符串.

python2 默認情況下 字符串 的類型是 str 類型, 如果需要得到 unicode 類型的字符串, 需要使用下面的方式進行聲明:

my_str = u"lowmanisbusy" # 在變量前面加上 u

在 python2 中如果沒有重新指定字符編碼, 定義中文的字符串時, 需要加上 "u", 指明該字符串為 unicode 類型, 指定使用unicode編碼對其進行編碼保存:

my_zh_str = u"渣男不但丑" # 在變量前面加上 u

unicode編碼: unicode編碼為世界上所有字符都分配了一個唯一編號, 為十六進制, 如中文簡體漢字 “渣” 的 Unicode編號就是 6E23, 在 python2就是 "\u6e23", 但是unicode僅僅定義了每個字符的編號,并沒有定義如何將這個編號進行存儲的方式,所以后來出現了utf-8, gbk等編碼格式, 它們都是 unicode 的一種實現方式, 仍然使用了unicode 中的唯一編號, 個人對其的簡單理解就是在unicode編碼的基礎之上又定義了對字符的存儲方式.

在python3中字符串分為 str 和 bytes 兩種類型

  Str To Bytes 使用 encode(), 編碼
  Bytes To Str 使用 decode(), 解碼

這里需要說明的是, python3 中 bytes 類型的字符串, 就相當于 python2 中 str 類型的字符串, python3中沒有unicode類型的字符串, 這里其實涉及到默認編碼的問題, python3默認字符編碼為:utf-8, python2默認字符編碼為:ASCII, ASCII碼 包含了128個字符, 其中包括所有的英文字符, 阿拉伯數字, 標點符號, 控制符號等, 卻沒有中文, 中文是象形文字, 需要使用到更多的字節進行組合來表示出每個漢字, 因此ASCII是無法滿足對中文的表示的, 所以 python2中如果沒有重新設置字符編碼的話,代碼中就不允許出現str類型的中文字符串(可以指定為unicode類型), 因為Cpython2解釋器無法識別. 至于 ASCII, UNICODE, UTF-8 之間的關系與區別這里就不細說了, 可以自行去了解一下( utf-8編碼  是  unicode編碼 的一種實現方式, 個人理解可以認為是下面這樣一種關系: utf-8 <---> unicode <--->byte, 最終,數據的傳輸仍然是以二進制的形式一個一個字節進行傳輸的)

默認情況下,python3中字符串的類型為 str, 在web框架中, 會自動將 str轉換成 byte 向前端返回.

當需要將某種編碼格式的bytes轉換另外一種編碼格式的bytes時需要先按原來的編碼格式進行解碼成str類型, 再使用新的編碼格式轉換為bytes類型

如: 若存在變量 my_bt, 其為編碼格式 gbk 的 bytes, 需將其轉換為utf-8的編碼格式,需要進行如下的處理:

my_str = my_bt.decode("gbk") # 解碼
  my_bt = my_str.encode("utf-8") # 重新編碼

 因為 python3 中沒有 unicode 類型的字符串, 所有在 python3 中使用下面這種方式定義字符串是沒有意義的

my_str = u"渣男不但丑"

ps:下面看下Python2之unicode轉字符串

str.encode('unicode-escape').decode('string_escape')

總結

以上所述是小編給大家介紹的python2 中 unicode 和 str 之間的轉換及與python3 str 的區別,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

印江| 曲阳县| 准格尔旗| 西乌| 庆城县| 略阳县| 昭平县| 青川县| 宁明县| 古交市| 方城县| 吴桥县| 香格里拉县| 贺州市| 桦南县| 清远市| 仁布县| 廊坊市| 溧水县| 昆山市| 霍山县| 茶陵县| 甘肃省| 翁牛特旗| 杭州市| 沂源县| 鄄城县| 双流县| 平罗县| 墨竹工卡县| 同德县| 剑川县| 成武县| 北安市| 嵩明县| 马山县| 丹东市| 琼结县| 汉寿县| 西乡县| 怀远县|