python2.7中的UnicodeDecodeError: 'ascii' codec can't decode byte 0

使用ez_setup.py安装setuptools报错如下
Traceback (most recent call last):
  File "httpservice.py", line 5, in <module>
    import SimpleHTTPServer
  File "C:\Python27\lib\SimpleHTTPServer.py", line 27, in <module>
    class SimpleHTTPRequestHandler(BaseHTTPServer.BaseHTTPRequestHandler):
  File "C:\Python27\lib\SimpleHTTPServer.py", line 208, in SimpleHTTPRequestHandler
    mimetypes.init() # try to read system mime.types
  File "C:\Python27\lib\mimetypes.py", line 358, in init
    db.read_windows_registry()
  File "C:\Python27\lib\mimetypes.py", line 258, in read_windows_registry
    for subkeyname in enum_types(hkcr):
  File "C:\Python27\lib\mimetypes.py", line 249, in enum_types
    ctype = ctype.encode(default_encoding) # omit in 3.x!
UnicodeDecodeError: 'ascii' codec can't decode byte 0xb0 in position 1: ordinal not in range(128)

解决方法:

通过分析最后的错误提示,是由于setuptools包中的setup.py编码格式错误,导致无法安装,以上虽然报错,但是setuptools-5.5.zip已经下载完成。那么就可以通过手工安装setuptools包:

1、解压setuptools-5.5.zip至C:\Python27\Lib\site-packages\setuptools-5.5

2、修改setup.py,在代码中添加如下几句即可: 

修改默认的编码方式

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

3、同时,打开python的Lib文件夹下的 mimetypes.py 文件,找到大概256行的

‘default_encoding = sys.getdefaultencoding()’。

在这行前面添加三行:

if sys.getdefaultencoding() != 'gbk':  
    reload(sys)  
    sys.setdefaultencoding('gbk')
default_encoding = sys.getdefaultencoding() 

参考:http://blog.youkuaiyun.com/scape1989/article/details/24535441

4、在cmd窗口中进入Python27\Lib\site-packages\setuptools-5.5目录,然后输入:python setup.py install,即可安装成功

5、然后就会在python的安装目录中生成scripts目录,其中有easy_install.exe

6、设置环境变量。

我的电脑→右键→属性→高级→环境变量,在PATH值里面,添加c:\Python27\Scripts


最后可以在命令行运行easy_install了

参考文章:https://www.cnblogs.com/sikongluoxing/p/3910601.html?utm_source=tuicool

### 回答1: python3 unicodedecodeerror: 'ascii' codec can't decode byte 0xc4。 这个错误是因为Python3在处理字符串时,使用的默认编码是ASCII。当遇到不是ASCII范围内的字符时,就会出现这个错误。 要解决这个问题,可以使用两种方法: 1.Python文件的开头添加以下代码,将默认编码设置为UTF-8: ``` # -*- coding: utf-8 -*- ``` 2. 在处理字符串时,使用显示的编码转换函数,将字符串转换为Unicode编码: ``` string = b"\xc4\x80\x80" decoded_string = string.decode("utf-8") ``` 这样就可以避免'ascii' codec can't decode byte 0xc4错误的出现。 ### 回答2: 这个错误是因为在Python 3中,默认的字符编码是ASCII,而在处理某个字符串时,遇到了无法解码的字节序列(byte sequence),所以引发了`UnicodeDecodeError`异常。根据给出的错误信息`'ascii' codec can't decode byte 0xc4`,该字节序列为`\xc4`。 要解决这个问题,我们可以通过以下几种方法来进行处理: 1. 使用正确的编码格式解码:可以通过指定正确的编码格式来解码该字节序列。例如,如果该字节序列使用的是UTF-8编码,可以通过`decode('utf-8')`来解码,如:`string.decode('utf-8')`。 2. 忽略无法解码的字符:可以通过在解码时设置错误处理标志(ignore)来忽略无法解码的字符。例如,使用`decode('ascii', errors='ignore')`来忽略无法解码的字符,如:`string.decode('ascii', errors='ignore')`。 3. 使用替代字符代替无法解码的字符:可以通过在解码时设置错误处理标志(replace)来使用替代字符代替无法解码的字符。例如,使用`decode('ascii', errors='replace')`来使用问号(?)替代无法解码的字符,如:`string.decode('ascii', errors='replace')`。 4. 预先指定字符串的编码格式:在处理字符串之前,可以显式地指定字符串的编码格式。例如,如果字符串采用的是UTF-8编码,可以在字符串前面加上`u`前缀,如:`string = u"字符串"`。 需要根据具体情况选择合适的处理方法,以解决该编码错误。 ### 回答3: Python3的编码方式默认为ASCII,而当遇到无法识别的字符时就会错。在你的情况中,错是因为你尝试使用ASCII编解码一个包含了0xc4字节的字符串。如果你想要解决这个问题,有以下两种方法: 1. 在字符串前加上"u",表示该字符串采用unicode编码。例如:s = u"\xc4"。这样,Python会知道如何正确地解码这个字符。 2. 在字符串前加上"b",表示该字符串采用字节编码。例如:s = b"\xc4"。这样,Python会将字符串作为字节序列处理,并不会尝试进行编解码。 需要注意的是,以上方法只是对于单个字符有效,如果是处理整个字符串,你可能需要采用其他方法,如使用正确的编码方式来解码。 另外,你也可以修改Python的默认编码方式来避免这个问题。这可以通过设置PYTHONIOENCODING环境变量来实现,例如: export PYTHONIOENCODING=utf-8 希望以上回答能帮到你解决问题。如果你有任何疑问,欢迎追问!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值