UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-1: ordinal not in range(128)

本文介绍了如何解决Python中出现的UnicodeEncodeError问题,通过修改Python的默认编码为UTF-8来避免非ASCII字符引起的错误,并提供了持久化设置的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天安装了PyScripter编辑器,刚要写代码,突然就出现异常:

如下:

<span style="font-size:14px;color:#ff0000;">>>> Traceback (most recent call last):
  File "<string>", line 378, in findModuleOrPackage
  File "<string>", line 367, in find_dotted_module
UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-1: ordinal not in range(128)</span>

python在安装时,默认的编码是ascii。经常出现它无法处理非ascii编码的情况。此时需要手动修改它的编码字符集。

    查询系统默认编码:

    在Shell中,输入python,进入python解释器。
    >>>import sys 
    >>>sys.getdefaultencoding()

    即可。


    如果想设置默认编码: 

    >>>sys.setdefaultencoding('utf8')

    即可把默认编码设置为utf8。

    但是如果重启python解释器,默认编码就又变回ascii了。

    如果希望把系统默认编码永久设置为utf8,则:

    在python的Lib\site-packages文件夹下新建一个sitecustomize.py,内容为: 

# encoding=utf8
import sys
reload(sys)
sys.setdefaultencoding('utf8')



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


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值