setdefaultencoding函数使用详解

kkkkk 2018年12月17日 23:06 Python高级

sys.getdefaultencoding()是设置默认的string的编码格式,如果你在python中进行编码和解码的时候,不指定编码方式,那么python就会使用defaultencoding。

而python2.x的的defaultencoding是ascii,这也就是大多数python编码报错:“UnicodeDecodeError: 'ascii' codec can't decode byte ......”的原因。

与此有类似功能的# coding:utf-8 作用是定义源代码的编码. 如果没有定义, 此源码中是不可以包含中文字符串的.

注意:python2.7以后setdefaultencoding就废弃掉了,所以在python3.x中不可使用


代码实例:

#!/usr/bin/env python    
#encoding: utf-8  
import sys   #引用sys模块进来,并不是进行sys的第一次加载  
reload(sys)  #重新加载sys  
sys.setdefaultencoding('utf8')  ##调用setdefaultencoding函数

可以正确的执行,可是下面的代码会出错

#!/usr/bin/env python    
#encoding: utf-8  
import sys     
sys.setdefaultencoding('utf8')

要在调用setdefaultencoding时必须要先reload一次sys模块,因为这里的import语句其实并不是sys的第一次导入语句,也就是说这里其实可能是第二、三次进行sys模块的import,这里只是一个对sys的引用,只能reload才能进行重新加载。


那么为什么要重新加载,而直接引用过来则不能调用该函数呢?因为setdefaultencoding函数在被系统调用后被删除了,所以通过import引用进来时其实已经没有了,所以必须reload一次sys模块,这样setdefaultencoding才会为可用,才能在代码里修改解释器当前的字符编码。


在python安装目录的Lib文件夹下,有一个叫site.py的文件,在里面可以找到main() --> setencoding()-->sys.setdefaultencoding(encoding),因为这个site.py每次启动python解释器时会自动加载,所以main函数每次都会被执行,setdefaultencoding函数一出来就已经被删除了。


文章评论(0)
  • avatar kkkkkk 2018年12月21日 11:31
    太假了吧!
    kkkkk
    2018年12月21日 11:16
    叙事鸡零狗碎,议论空洞粗浅,结构呆板单一。
    回复
  • avatar kkkkkk 2018年12月21日 11:31
    潭州python学院老师真棒!
    kkkkklxinde
    2018年12月21日 11:17
    情感丰富,事件趣卓。真情流露,感人肺腑。文畅情达,雄深雅健。词句生硬,文意不明。
    回复
  • avatar kkkkklxinde 2018年12月21日 11:17
    情感丰富,事件趣卓。真情流露,感人肺腑。文畅情达,雄深雅健。词句生硬,文意不明。
    回复
  • avatar kkkkk 2018年12月21日 11:16
    叙事鸡零狗碎,议论空洞粗浅,结构呆板单一。
    回复