moviepy用VideoFileClip加载视频时报UnicodeDecodeError: utf-8 codec cant decode byte invalid start byte错误

使用moviepy用:
clip1 = VideoFileClip('F:\\video\\3.mp4')加载视频时报错,如下:

Traceback (most recent call last):
File “<pyshell#3>”, line 1, in
clip1 = VideoFileClip(‘F:\video\3.mp4’)
File “C:\Program Files\Python37\lib\site-packages\moviepy\video\io\VideoFileClip.py”, line 91, in init
fps_source=fps_source)
File “C:\Program Files\Python37\lib\site-packages\moviepy\video\io\ffmpeg_reader.py”, line 36, in init
fps_source)
File “C:\Program Files\Python37\lib\site-packages\moviepy\video\io\ffmpeg_reader.py”, line 259, in ffmpeg_parse_infos
infos = error.decode(‘utf8’)
UnicodeDecodeError: ‘utf-8’ codec can’t decode byte 0xb9 in position 1721: invalid start byte

这种情况只在少数视频文件处理时报错,应该是解码问题,打开moviepy\video\io\ffmpeg_reader.py文件,将该行代码:
infos = error.decode(‘utf8’)
改为:infos = error.decode(‘ANSI’)
重启解释器后再执行问题顺利解决。

更多moviepy的介绍请参考《PyQt+moviepy音视频剪辑实战文章目录》或《moviepy音视频开发专栏》。

关于收费专栏

老猿的付费专栏《使用PyQt开发图形界面Python应用》专门介绍基于Python的PyQt图形界面开发基础教程,付费专栏《moviepy音视频开发专栏》详细介绍moviepy音视频剪辑合成处理的类相关方法及使用相关方法进行相关剪辑合成场景的处理,两个专栏加起来只需要19.9元,都适合有一定Python基础但无相关专利知识的小白读者学习。这2个收费专栏都有对应免费专栏,只是收费专栏的文章介绍更具体、内容更深入、案例更多。

对于缺乏Python基础的同仁,可以通过老猿的免费专栏《专栏:Python基础教程目录》从零开始学习Python。

如果有兴趣也愿意支持老猿的读者,欢迎购买付费专栏。

跟老猿学Python、学5G!

`UnicodeDecodeError: &#39;utf-8&#39; codec can&#39;t decode byte 0x99 in position 26: invalid start byte` 这是一个常见的 Python 错误提示,表示程序尝试将某些二进制数据解码为 UTF-8 编码的字符串时失败了。 ### 具体原因分析: UTF-8 是一种常用的字符编码方式,它能够处理大多数语言的文字。然而,并不是所有的字节序列都可以被合法地解释为 UTF-8 字符串。错误信息中的 `byte 0x99` 表示在位置 26 的地方遇到了无法解析的有效起始字节 (invalid start byte) ,因此导致了解码失败。 #### 可能的原因包括: 1. **文件内容非 UTF-8 格式**:如果读取了一个非 UTF-8 文件(例如 ISO-8859、GBK 等),却试图用 UTF-8 解码,则会发生此错误。 2. **损坏的数据流**:传输过程中可能导致数据异常丢失或者篡改了一些关键位元组。 3. **错误指定编码类型**:当从网络请求或其他来源获取文本时,开发者手动指定了错误的解码模式。 ### 潜在解决方案: 1. 首先确认源数据的实际编码格式是什么。可以借助工具库如 chardet 或 cchardet 来探测未知文件的真实编码形式; ```python import chardet rawdata = open(&#39;yourfile&#39;, &#39;rb&#39;).read() result = chardet.detect(rawdata) print(result[&#39;encoding&#39;]) # 输出检测到的编码名 ``` 2. 使用正确的编码方式进行解码操作。比如若得知原文件采用 GBK 而非 UTF-8,那么应更改代码如下所示: ```python with open("path/to/file", "r", encoding="gbk") as f: content = f.read() ``` 3. 对于确实包含不可识别字节的情况,在确保不影响整体功能的前提下忽略它们也是一种选择: ```python decoded_string = your_bytes.decode(&#39;utf-8&#39;,&#39;ignore&#39;) ``` 4. 替换非法字符而非直接跳过也可以是一种办法: ```python decoded_string = your_bytes.decode(&#39;utf-8&#39;, errors=&#39;replace&#39;) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

LaoYuanPython

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值