内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

Python中字符編碼轉(zhuǎn)碼之GBK,UTF8互轉(zhuǎn)的示例分析-創(chuàng)新互聯(lián)

這篇文章給大家分享的是有關(guān)Python中字符編碼轉(zhuǎn)碼之GBK,UTF8互轉(zhuǎn)的示例分析的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

圖木舒克ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)建站的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18982081108(備注:SSL證書合作)期待與您的合作!一、Python字符編碼介紹

1、須知:

在python 2中默認編碼是 ASCII,而在python 3中默認編碼是 unicode

unicode 分為utf-32 (占4個字節(jié)),utf-16(占兩個字節(jié)),utf-8(占1-4個字節(jié)),所以utf-16 是最常用的unicode版本,但是在文件里存的還是utf-8,因為utf8省空間

在python 3,encode編碼的同時會把stringl變成bytes類型,decode解碼的同時會把bytes類型變成string類型

在unicode編碼中 1個中文字符=2個字節(jié),1個英文字符 = 1個字節(jié),切記:ASCII是不能存中文字符的

utf-8是可變長字符編碼,它是unicode的優(yōu)化,所有的英文字符依然按ASCII形式存儲,所有的中文字符統(tǒng)一是3個字節(jié)

unicode包含了所有國家的字符編碼,不同字符編碼之間的轉(zhuǎn)換都需要經(jīng)過unicode的過程

python本身的默認編碼是utf-8

2、py2中的編碼和轉(zhuǎn)碼的過程,如圖:

Python中字符編碼轉(zhuǎn)碼之GBK,UTF8互轉(zhuǎn)的示例分析

注:因為unicode是中間編碼,任何字符編碼之前的轉(zhuǎn)換都必須解碼成unicode,在編碼成需要轉(zhuǎn)的字符編碼

二、字符編碼的轉(zhuǎn)換

1、py2字符編碼的轉(zhuǎn)換,代碼如下:

#! /usr/bin/env python
# -*- coding:utf-8 -*-
# __auther__ == luoahong
 
s = "我是學員"
#utf-8解碼成unicode編碼
s_to_unicode = s.decode("utf-8")
print("--------s_to_unicode-----")
print(s_to_unicode)
#然后unicode再編碼成gbk
s_to_gbk = s_to_unicode.encode("gbk")
print("-----s_to_gbk------")
print(s_to_gbk)
#gbk解碼成unicode再編碼成utf-8
gbk_to_utf8 = s_to_gbk.decode("gbk").encode("utf-8")
print("------gbk_to_utf8-----")
print(gbk_to_utf8)
 
#輸出
--------s_to_unicode-----
我是學員
-----s_to_gbk------
??????
------gbk_to_utf8-----
我是學員

 注:以上這種情況適合字符是非unicode編碼請款下,但是如果字符編碼已經(jīng)是Unicode的了咋辦呢?廣告回來,更加精彩。。。。。

2、字符編碼已經(jīng)是unicode情況下,代碼如下:

#! /usr/bin/env python
# -*- coding:utf-8 -*-
# __auther__ == luoahong
 
#u代碼字符編碼是unicode
s = u'你好'
#已經(jīng)是unicode,所以這邊直接是編碼成gbk
s_to_gbk = s.encode("gbk")
print("----s_to_gbk----")
print(s_to_gbk)
#這邊再解碼成unicode然后再編碼成utf-8
gbk_to_utf8 = s_to_gbk.decode("gbk").encode("utf-8")
print("-----gbk_to_utf8---")
print(gbk_to_utf8)
#輸出
----s_to_gbk----
???
-----gbk_to_utf8---
你好

注:在python2中,在文件的開頭指定字符編碼,是要告訴解釋器我現(xiàn)在的字符編碼使用的是utf-8,那我在打印的中文時候,那么在utf-8中包含中文字符,那么可以打印出來。那么如果你不制定字符編碼,默認使用系統(tǒng)編碼,如果你的系統(tǒng)編碼是ASCII,那么就會報錯,因為ASCII不能存中文字符。

3、py3的字符編碼轉(zhuǎn)換

在須知中已經(jīng)說到python 3的編碼,默認是unicode,所以字符編碼之間的轉(zhuǎn)換不需要decode過程,直接encode即可,代碼如下:

#! /usr/bin/env python
# __auther__ == luoahong
#無需聲明字符編碼,當然你聲明也不會報錯
 
s = '你好'
# 字符串s已經(jīng)是unicode編碼,無需decode,直接encode
s_to_gbk = s.encode("gbk")
print("----s_to_gbk----")
print(s_to_gbk)
#這邊還是一樣,gbk需要先解碼成unicode,再編碼成utf-8
gbk_to_utf8 = s_to_gbk.decode("gbk").encode("utf-8")
print("-----gbk_to_utf8---")
print(gbk_to_utf8)
#解碼成unicode字符編碼
utf8_decode = gbk_to_utf8.decode("utf-8")
print("-------utf8_decode----")
print(utf8_decode)
 
#輸出
----s_to_gbk----
b'\xc4\xe3\xba\xc3'
-----gbk_to_utf8---
b'\xe4\xbd\xa0\xe5\xa5\xbd'
-------utf8_decode----
你好

 注:在python 3,encode編碼的同時會把stringl變成bytes類型,decode解碼的同時會把bytes類型變成string類型,所以你就不難看出encode后的把它變成了一個bytes類型的數(shù)據(jù)。還有需要特別注意的是:不管是否在python 3的文件開頭申明字符編碼,只能表示,這個python文件是這個字符編碼,文件中的字符串還是unicode。

感謝各位的閱讀!關(guān)于“Python中字符編碼轉(zhuǎn)碼之GBK,UTF8互轉(zhuǎn)的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

標題名稱:Python中字符編碼轉(zhuǎn)碼之GBK,UTF8互轉(zhuǎn)的示例分析-創(chuàng)新互聯(lián)
瀏覽地址:http://m.rwnh.cn/article4/ddooie.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器、外貿(mào)建站網(wǎng)站設(shè)計公司、域名注冊自適應網(wǎng)站、手機網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管
南汇区| 关岭| 宜兰市| 英超| 南充市| 会理县| 乐陵市| 洪江市| 温泉县| 卓尼县| 清水河县| 威海市| 兴仁县| 英山县| 博兴县| 颍上县| 清河县| 赤壁市| 河曲县| 友谊县| 荆门市| 西丰县| 新邵县| 德阳市| 金堂县| 保靖县| 凤冈县| 三门县| 邢台县| 五大连池市| 岳池县| 布尔津县| 怀柔区| 马公市| 五家渠市| 会昌县| 大宁县| 惠东县| 定日县| 堆龙德庆县| 曲麻莱县|