新聞中心
之前我們講過了默認(rèn)編碼,因?yàn)榉浅:唵?,所以很多小伙伴一下子就學(xué)會了。經(jīng)過眾多小伙伴的強(qiáng)烈要求,小編查詢了python中的其他編碼,有發(fā)現(xiàn)了一個特別簡單的json編碼,python小白也能一學(xué)就會。本篇文章同樣會舉一個簡單的代碼示例,幫助大家記憶和理解。接下來就是揭曉神秘代碼的時刻,讓我們期待起來。

下面以一個例子展開:
In [121]: json.dumps('中文', ensure_ascii=True)
Out[121]: '"\\u4e2d\\u6587"'
In [122]: json.dumps('中文', ensure_ascii=False)
Out[122]: '"中文"'
復(fù)制代碼
可以看到, 在 ensure_ascii 為 True 的情況下, 中文 被編碼成了 Unicode 碼, 為 False 才能正常顯示, 但是這跟 ASCII 有什么關(guān)系呢? 來看一下 官方文檔 對這個參數(shù)的解釋:
如果 ensure_ascii 是 true (即默認(rèn)值),輸出保證將所有輸入的非 ASCII 字符轉(zhuǎn)義。如果 ensure_ascii 是 false,這些字符會原樣輸出。
復(fù)制代碼
現(xiàn)在稍微明白了, 在 ensure_ascii 為 True 的情況下, 如果字符串中存在 非ASCII 字符就將其轉(zhuǎn)義, 根據(jù)結(jié)果可以知道這個字符被轉(zhuǎn)義為 Unicode 碼并格式化成了一個字符串, 注意 "\\u4e2d\\u6587" 與 "\u4e2d\\u6587" 是不同的, 前者是長度為 12 的字符串, 后者會被 Python 直接解析為 中文 , 長度為 2 . 這也就是我一開始出現(xiàn)的問題, 直接將轉(zhuǎn)義的字符串在網(wǎng)絡(luò)上傳輸可能會無法被識別. 比如 中文 被轉(zhuǎn)義成 \\u4e2d\\u6587 , 而服務(wù)器如果不知道它是被轉(zhuǎn)義過的字符串, 那它就是一個長度為 12 的普通字符串, 肯定會識別出錯. 而將 ensure_ascii 設(shè)為 False 就不會進(jìn)行轉(zhuǎn)義, 使用原始字符。
以上就是python3中json編碼的介紹和使用的方法了。想要學(xué)習(xí)更多pytho方面的知識,一定要經(jīng)常來看看小編寫的文章。編碼方面的文章很多小伙伴感興趣,所以小編持續(xù)更新的。
當(dāng)前名稱:創(chuàng)新互聯(lián)Python教程:python3中json編碼是什么?怎么用?
網(wǎng)站網(wǎng)址:http://www.dlmjj.cn/article/djhossg.html


咨詢
建站咨詢
