Python 2.x 的中文显示方法 - 未分类

Python 2.x 的中文显示方法

发布于 2021-02-24 字数 1885 浏览 998 评论 0

Python 在安装时,默认的编码是 ascii,当程序中出现非 ascii 编码时,python 的处理常常会报这样的错

UnicodeDecodeError: 'ascii' codec can't decode byte 0x?? in position 1: ordinal not in range(128),

python 没办法处理非 ascii 编码的,此时需要自己设置将 python 的默认编码,一般设置为 utf8 的编码格式。

查询系统默认编码可以在解释器中输入以下命令: Python 代码

>>>sys.getdefaultencoding() 

设置默认编码时使用: Python 代码

>>>sys.setdefaultencoding('utf8')  

可能会报

AttributeError: 'module' object has no attribute 'setdefaultencoding'    

的错误,执行 reload(sys),在执行以上命令就可以顺利通过。

此时在执行 sys.getdefaultencoding() 就会发现编码已经被设置为 utf8 的了,但是在解释器里修改的编码只能保证当次有效,在重启解释器后,会发现,编码又被重置为默认的 ascii 了,那么有没有办法一次性修改程序或系统的默认编码呢。

有2种方法设置python的默认编码:

一个解决的方案在程序中加入以下代码: Python 代码

import sys 
reload(sys) 
sys.setdefaultencoding('utf8')   

另一个方案是在 /usr/local/lib/python.27/site-packages 或者 /usr/lib/python2.7 下新建一个 sitecustomize.py,内容为: Python 代码, 两个路径的原因是因为系统不同的原因,debian 和 ubuntu 存放的目录是后者,其他没有测试。

# encoding=utf8 

import sys   
reload(sys) 
sys.setdefaultencoding('utf8')  

重启 python 解释器,执行 sys.getdefaultencoding(),发现编码已经被设置为utf8的了,多次重启之后,效果相同,这是因为系统在python启动的时候,自行调用该文件,设置系统的默认编码,而不需要每次都手动的加上解决代码,属于一劳永逸的解决方法。

还有一种解决方案是在程序中所有涉及到编码的地方,强制编码为 utf8,即添加代码 encode(“utf8”),这种方法并不推荐使用,因为一旦少写一个地方,将会导致大量的错误报告。

如果你对这篇文章有疑问,欢迎到本站 社区 发帖提问或使用手Q扫描下方二维码加群参与讨论,获取更多帮助。

扫码加入群聊

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

目前还没有任何评论,快来抢沙发吧!

关于作者

JSmiles

生命进入颠沛而奔忙的本质状态,并将以不断告别和相遇的陈旧方式继续下去。

2583 文章
29 评论
84935 人气
更多

推荐作者

猫性小仙女

文章 1 评论 0

qq_VO6LhT

文章 0 评论 0

猿舌电影

文章 0 评论 0

7556275422

文章 0 评论 0

YYQ_139

文章 0 评论 0