【亲测免费】 Decord 开源项目教程
2026-01-15 17:07:56作者:裘旻烁
1、项目介绍
Decord 是一个高效的视频加载器,专为深度学习设计,具有智能的随机播放功能,使其非常易于使用。Decord 旨在处理深度学习中常见的随机访问模式,提供流畅的视频加载体验,类似于随机图像加载器。此外,Decord 还能够解码视频和音频文件中的音频,提供视频和音频同步解码的一站式解决方案。
2、项目快速启动
安装
通过 pip 安装
pip install decord
从源码安装
Linux
- 安装系统依赖包:
sudo apt-get update
sudo apt-get install -y build-essential python3-dev python3-setuptools make cmake ffmpeg libavcodec-dev libavfilter-dev libavformat-dev libavutil-dev
- 克隆仓库并编译:
git clone --recursive https://github.com/dmlc/decord
cd decord
mkdir build && cd build
cmake -DUSE_CUDA=0 -DCMAKE_BUILD_TYPE=Release
make
- 安装 Python 绑定:
cd ../python
python3 setup.py install --user
macOS
- 安装构建工具:
xcode-select --install
brew install cmake ffmpeg
- 克隆仓库并编译:
git clone --recursive https://github.com/dmlc/decord
cd decord
mkdir build && cd build
cmake -DCMAKE_BUILD_TYPE=Release
make
- 安装 Python 绑定:
cd ../python
python3 setup.py install --user
Windows
- 安装依赖:
choco install git cmake ffmpeg python
- 克隆仓库并编译:
git clone --recursive https://github.com/dmlc/decord
cd decord
mkdir build && cd build
cmake -DCMAKE_CXX_FLAGS="/DDECORD_EXPORTS" -DCMAKE_CONFIGURATION_TYPES="Release" -G "Visual Studio 15 2017 Win64"
- 安装 Python 绑定:
cd ../python
python3 setup.py install --user
使用示例
使用 VideoReader 读取视频帧
from decord import VideoReader
from decord import cpu
vr = VideoReader('examples/flipping_a_pancake.mkv', ctx=cpu(0))
print('视频帧数:', len(vr))
for i in range(len(vr)):
frame = vr[i]
print(frame.shape)
frames = vr.get_batch([1, 3, 5, 7, 9])
print(frames.shape)
使用 VideoLoader 加载视频文件
from decord import VideoLoader
from decord import cpu
vl = VideoLoader(['1.mp4', '2.avi', '3.mpeg'], ctx=[cpu(0)], shape=(2, 320, 240, 3), interval=1, skip=5, shuffle=1)
print('总批次:', len(vl))
for batch in vl:
print(batch[0].shape)
3、应用案例和最佳实践
视频分类
Decord 可以用于视频分类任务中,高效地加载和处理视频数据。通过 VideoLoader 的智能随机播放功能,可以大大提高训练效率。
视频检索
在视频检索系统中,Decord 可以用于快速加载和处理视频帧,提取关键帧进行特征提取和匹配。
视频编辑
Decord 可以用于视频编辑软件中,提供高效的视频帧读取和处理功能,支持实时预览和编辑。
4、典型生态项目
MXNet
Decord 可以与 MXNet 深度学习框架结合使用,提供高效的视频数据加载和处理功能,适用于视频分类、检测等任务。
PyTorch
Decord 也可以与 PyTorch 结合使用,提供高效的视频数据加载和处理功能,适用于各种视频相关的深度学习任务。
TensorFlow
Decord 可以与 TensorFlow 结合使用,提供高效的视频数据加载和处理功能,适用于视频分类、生成等任务。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedJavaScript093- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
MiMo-V2.5-ProMiMo-V2.5-Pro作为旗舰模型,擅⻓处理复杂Agent任务,单次任务可完成近千次⼯具调⽤与⼗余轮上 下⽂压缩。Python00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
Kimi-K2.6Kimi K2.6 是一款开源的原生多模态智能体模型,在长程编码、编码驱动设计、主动自主执行以及群体任务编排等实用能力方面实现了显著提升。Python00
MiniMax-M2.7MiniMax-M2.7 是我们首个深度参与自身进化过程的模型。M2.7 具备构建复杂智能体应用框架的能力,能够借助智能体团队、复杂技能以及动态工具搜索,完成高度精细的生产力任务。Python00
热门内容推荐
最新内容推荐
3步掌握Mermaid Live Editor:让图表创作效率提升10倍3个高效研究工具,让你的学术工作流提升80%效率3步搞定黑苹果EFI:OpCore Simplify如何革新你的配置体验如何使用密码安全检测工具提升系统防护能力零基础2024新版:3步打造专属微信群智能助手3个高效技巧:ChilloutMix NiPrunedFp32Fix让你快速生成超逼真图像3步解锁OpCore Simplify:告别OpenCore配置烦恼,新手也能轻松上手如何3秒提取屏幕文字?Windows OCR工具实战指南Linux Notion客户端:如何突破生态壁垒实现无缝集成AI建筑设计草图生成工具:用ChilloutMix NiPrunedFp32Fix释放创意潜能
项目优选
收起
暂无描述
Dockerfile
700
4.5 K
Ascend Extension for PyTorch
Python
563
691
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
JavaScript
521
93
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
956
951
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
411
338
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.6 K
939
Oohos_react_native
React Native鸿蒙化仓库
C++
340
387
AscendNPU-IR是基于MLIR(Multi-Level Intermediate Representation)构建的,面向昇腾亲和算子编译时使用的中间表示,提供昇腾完备表达能力,通过编译优化提升昇腾AI处理器计算效率,支持通过生态框架使能昇腾AI处理器与深度调优
C++
128
209
昇腾LLM分布式训练框架
Python
148
176
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
140
221