python使用defaultencoding函数的简单示例

前端之家收集整理的这篇文章主要介绍了python使用defaultencoding函数的简单示例前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
对python这个高级语言感兴趣的小伙伴,下面一起跟随编程之家 jb51.cc的小编两巴掌来看看吧!

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中不可使用

代码实例:


# @param setdefaultencoding函数使用详解
# @author 编程之家 jb51.cc|512Pic.com 

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

# End www.jb51.cc

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


# @param setdefaultencoding函数使用详解
# @author 编程之家 jb51.cc|512Pic.com 

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

# End www.jb51.cc

要在调用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函数一出来就已经被删除了。

猜你在找的Python相关文章