解决:‘utf-8’ codec can’t decode byte(本质是from scipy.misc import imread问题)

一、问题

pip 时 ‘utf-8’ codec can’t decode byte

pip install imread 的过程中遇到了这个问题

UnicodeDecodeError: 'utf-8' codec can't decode byte 0xb2 in position 13: invalid start byte

image-20210819172220998

二、思路

一开始查到的各种解决方案都是编码上的问题,后来才发现原来是思路错了。
这个问题其实是因为 from scipy.misc import imread,imwrite 等方法已经被弃用。
Python已经将imread方法封装在了imageio模块当中。
因此方法三解决了我的问题,应该通过imageio模块来调取imread而不再是从scipy.misc中调取。
不过以下还是会提供三个方法

三、解决

1、方法一:版本中已移除该方法(有效)

如果是在以下语句中报错,可能是版本问题,这句调用代码已经被移除

from scipy.misc import imread,imsave

解决方案如下:

# 1.安装 imageio 库
pip install imageio
# 2.在python中
from imageio import imread
# 3.代码中调用方式
imread("xxxx.png")

参考博客:Python中from scipy.misc import imread报错的原因?

2、方法二:降低spicy版本(有效)

pip install scipy==1.2.1

这样也是可以的

3、方法三:修改编码方式

因为 python3 默认编码是unicode;python2是ASCII码;windows环境默认是gbk编码

修改 python安装目录下\Lib\site-packages\pip\compat的_init_.py,搜索 def console_to_str(s) 函数,修改代码为

def console_to_str(s):
    try:
        return s.decode(sys.__stdout__.encoding)
    except UnicodeDecodeError:
    	# 或者也可以尝试改为 cp936、GB2312、gb18030
        return s.decode('gbk')

image-20210819203639903

参考博客:

pip错误:‘utf-8’ codec can’t decode byte解决方法

UnicodeDecodeError: ‘utf-8’ codec can’t decode byte 0xb2 in position 99: invalid start byte

关于Python字符编码encode和decode

4、方法四:管理员运行

以管理员身份运行 cmd 或者 Anaconda Prompt

参考博客:Pip安装pyinstaller出现utf-8解码错误

5、其他(未尝试)

如用 Git Bush 命令行安装

Python pip 安装报错;‘utf-8’ codec can’t decode byte 0xce in position 72

windows下使用GitBash命令工具执行python文件

  • 1
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
UnicodeDecodeError是Python中的一个异常,表示在解码Unicode字符串时发生了错误。具体地说,"utf-8 codec can't decode byte 0x8f in position 18: invalid start byte"这个错误表示在使用UTF-8编解码器解码字节序列时,遇到了无效的起始字节0x8f。 UTF-8是一种变长编码方式,它使用1到4个字节来表示一个Unicode字符。在UTF-8编码中,每个字节的最高位用于标识该字节是否为一个字符的起始字节,如果一个字节的最高位为0,则表示该字节为一个字符的起始字节;如果最高位为1,则表示该字节为一个字符的后续字节。 在你提供的错误信息中,字节序列中的第18个字节0x8f被认为是无效的起始字节,因此无法正确解码。这可能是由于以下原因导致的: 1. 字节序列中包含了非UTF-8编码的字节。 2. 字节序列中的某些字节丢失或损坏。 3. 字符串本身不是以UTF-8编码保存的。 要解决这个问题,你可以尝试以下几种方法: 1. 确保输入的字节序列是以UTF-8编码保存的,并且没有丢失或损坏的字节。 2. 如果你知道输入的编码方式,可以尝试使用相应的编码器进行解码。 3. 如果你不确定输入的编码方式,可以尝试使用Python的chardet库来自动检测编码方式。 4. 如果你无法修复输入的字节序列,可以考虑使用错误处理机制来处理解码错误,例如忽略错误的字节或替换为特定的占位符。 希望以上信息对你有帮助!如果你还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值