新聞中心
我們都知道很多軟件里會自帶一些工具,大部分使用起來還是比較順手的,但是總會遇到一些不好用的工具,這時候我們就需要找一些其他的方法替換一下。提到utf-8小伙伴們肯定不陌生,我們在之前的文章中有反復提及。python的字符串默認的的是另一種編碼,很多人還是喜歡用utf-8,所以今天小編教大家改變默認的ascii編碼方法。

堅守“ 做人真誠 · 做事靠譜 · 口碑至上 · 高效敬業(yè) ”的價值觀,專業(yè)網(wǎng)站建設服務10余年為成都玻璃鋼坐凳小微創(chuàng)業(yè)公司專業(yè)提供企業(yè)網(wǎng)站制作營銷網(wǎng)站建設商城網(wǎng)站建設手機網(wǎng)站建設小程序網(wǎng)站建設網(wǎng)站改版,從內(nèi)容策劃、視覺設計、底層架構、網(wǎng)頁布局、功能開發(fā)迭代于一體的高端網(wǎng)站建設服務。
Python默認字符串采用的是ascii編碼方式,如下所示:
python -c "import sys; print sys.getdefaultencoding()" Ascii
可以通過#coding:utf-8 指定頁面默認編碼為utf-8(ps:但系統(tǒng)默認還是ascii)
字符串的編解碼都是以unicode為中間編碼,無法直接完成轉換,python會自動按其系統(tǒng)默認編碼方式解碼為unicode,再編碼成另一中編碼格式
比如:
#coding:utf-8
s = '中文'
print s.decode('gbk')報錯解決:
#!/usr/bin/python
# -*- coding: utf-8 -*-
import sys
# reload(sys)
# sys.setdefaultencoding('utf-8')
s = '中文'
print [s]
print s.encode('gbk')此時報錯為UnicodeDecodeError: 'ascii' codec can't decode byte 0xe4 in position 0: ordinal not in range(128) 猜測雖然指定了當前頁面為utf-8,但因為直接encode()轉換程序會自動先按照系統(tǒng)默認的編碼(此時還是ascii) decode一次成unicode,再從unicode編碼為gbk, 因為s編碼為utf-8,明顯解碼出錯
有兩種解決辦法
1 手動解碼 print s.decode(‘utf-8’).encode(‘gbk’)
2 改變系統(tǒng)默認編碼,即加入這兩句
reload(sys)
sys.setdefaultencoding('utf-8')相信看完本篇文章后,我們已經(jīng)學會把默認字符串采用的ascii編碼換成utf-8了,相信后者大家使用起來更為順手。更多Python學習指路:PyThon學習網(wǎng)教學中心。
本文名稱:創(chuàng)新互聯(lián)Python教程:python3如何改變默認的ascii編碼?
瀏覽路徑:http://www.5511xx.com/article/djsjchs.html


咨詢
建站咨詢
