Python ffmpeg-downloader package automatically downloads the latest FFmpeg prebuilt binaries for Windows, Linux, & MacOS. It's cli interface mimics that of pip to install, uninstall, list, search, and download available FFmpeg versions. This package is ideal for those who:
- Use the git snapshot version of FFmpeg
- Are in Windows environment
Those who intend to use a release version in Linux and MacOS are encouraged to install via the OS package manager (e.g., apt-get for Ubuntu and brew for MacOS).
The FFmpeg builds will be downloaded from 3rd party hosts:
| Windows & Linux | https://github.com/BtbN/FFmpeg-Builds |
| Windows | https://www.gyan.dev/ffmpeg/builds |
| Linux | https://johnvansickle.com/ffmpeg |
| MacOS | https://osxexperts.net/ |
| MacOS | https://evermeet.cx/ffmpeg |
If you appreciate their effort to build and host these builds, please consider donating on their websites.
Note that BtbN and Gyan offer multiple build types. Use the ffdl.list command.
pip install ffmpeg-downloaderIn cli, use ffdl command after the package is installed. Alternately, you can call the module by python -m ffmpeg_downloader. For full help, run:
ffdl -h <command>
ffdl installThis command downloads and installs the latest FFmpeg release. You will see the progress messages similar to the following:
Collecting ffmpeg
Using cached ffmpeg-5.1.2-essentials_build.zip (79 MB)
Installing collected FFmpeg binaries: 5.1.2@essentials
Successfully installed FFmpeg binaries: 5.1.2@essentials in
C:\Users\User\AppData\Local\ffmpegio\ffmpeg-downloader\ffmpeg\binIn Linux, symlinks fo the installed binaries are automatically created in ~/.local/bin or ~/bin so the FFmpeg commands are immediately available (only if one of these directories already exists).
In Windows and MacOS, the binary folder can be added to the system path by --add-path option:
ffdl install --add-pathThe new system paths won't be applied to the current console window. You may need to close and reopen or possibly log out and log back in for the change to take effect.
ffdl install snapshotUse list and search commands to see available releases.
The list command lists all the releases:
ffdl listAn example Linux output:
Version Available Builds (*=cached) Provider
------------- ----------------------------------- -----------------
3.3.4 static johnvansickle.com
3.4.2 static johnvansickle.com
4.0.3 static johnvansickle.com
4.1.4 static johnvansickle.com
4.2.1 static johnvansickle.com
4.2.2 static johnvansickle.com
4.3.1 static johnvansickle.com
4.3.2 static johnvansickle.com
4.4 static johnvansickle.com
4.4.1 static johnvansickle.com
5.0.1 static johnvansickle.com
5.1.1 static johnvansickle.com
5.1.5.post106 gpl, gpl-shared, lgpl, lgpl-shared btbn
5.1.6.post16 gpl, gpl-shared, lgpl, lgpl-shared btbn
6.0 static johnvansickle.com
6.0.1 static johnvansickle.com
6.1.1.post329 gpl, gpl-shared, lgpl, lgpl-shared btbn
6.1.2.post192 gpl, gpl-shared, lgpl, lgpl-shared btbn
7.0.1.post221 gpl, gpl-shared, lgpl, lgpl-shared btbn
7.0.2 static* johnvansickle.com
7.0.2.post6 gpl, gpl-shared, lgpl, lgpl-shared btbn
7.1.post214 gpl, gpl-shared, lgpl, lgpl-shared btbn
7.1.1.post57 gpl, gpl-shared, lgpl, lgpl-shared btbn
7.1.2.post7 gpl, gpl-shared, lgpl, lgpl-shared btbn
7.1.3.post46 gpl, gpl-shared, lgpl, lgpl-shared btbn
8.0.post30 gpl, gpl-shared, lgpl, lgpl-shared btbn
8.0.1.post66 gpl, gpl-shared, lgpl, lgpl-shared btbn
8.1.post11 gpl*, gpl-shared, lgpl, lgpl-shared btbn
8.1.1.post1 gpl*, gpl-shared*, lgpl* btbn
8.1.1.post2 gpl, gpl-shared, lgpl, lgpl-shared btbn
To install specific build, ffdl install <version>@<build_type>Note: Currently -shared builds in Linux could not be used in Python
Windows output:
Version Available Builds (*=cached) Provider
------------- ---------------------------------- ----------
4.4 essentials, full, full-shared gyan
4.4.1 essentials, full, full-shared gyan
5.0 essentials, full, full-shared gyan
5.0.1 essentials, full, full-shared gyan
5.1 essentials, full, full-shared gyan
5.1.1 essentials, full, full-shared gyan
5.1.2 essentials, full, full-shared gyan
5.1.5.post106 gpl, gpl-shared, lgpl, lgpl-shared btbn
5.1.6.post16 gpl, gpl-shared, lgpl, lgpl-shared btbn
6.0 essentials, full, full-shared gyan
6.1 essentials, full, full-shared gyan
6.1.1 essentials, full, full-shared gyan
6.1.1.post329 gpl, gpl-shared, lgpl, lgpl-shared btbn
6.1.2.post192 gpl, gpl-shared, lgpl, lgpl-shared btbn
7.0 essentials, full, full-shared gyan
7.0.1 essentials, full, full-shared gyan
7.0.1.post221 gpl, gpl-shared, lgpl, lgpl-shared btbn
7.0.2 essentials, full, full-shared gyan
7.0.2.post6 gpl, gpl-shared, lgpl, lgpl-shared btbn
7.1 essentials, full, full-shared gyan
7.1.post214 gpl, gpl-shared, lgpl, lgpl-shared btbn
7.1.1 essentials, full, full-shared gyan
7.1.1.post57 gpl, gpl-shared, lgpl, lgpl-shared btbn
7.1.2.post7 gpl, gpl-shared, lgpl, lgpl-shared btbn
7.1.3.post46 gpl, gpl-shared, lgpl, lgpl-shared btbn
8.0 essentials, full, full-shared gyan
8.0.post30 gpl, gpl-shared, lgpl, lgpl-shared btbn
8.0.1 essentials, full, full-shared gyan
8.0.1.post66 gpl, gpl-shared, lgpl, lgpl-shared btbn
8.1 essentials, full, full-shared gyan
8.1.post11 gpl, gpl-shared, lgpl, lgpl-shared btbn
8.1.1 essentials, full, full-shared gyan
8.1.1.post2 gpl, gpl-shared, lgpl, lgpl-shared btbn
To install specific build, ffdl install <version>@<build_type>For MacOS (arm64), only one file would be listed:
Version Available Builds (*=cached) Provider
--------- ----------------------------- --------------
8.1 static osxexperts.net
To install specific build, ffdl install <version>@<build_type>The search command lists only the releases that matches the query:
ffdl search 7 # lists all v7 releases
ffdl search @gpl # list all releases with gpl builds (of btbn)
ffdl search =7.0.2 # lists only v7.0.2 release, excluding 7.0.2post versionsAdd version number as the last argument of the install command similar as
the search command:
ffdl install 7 # install the latest v7 release
ffdl install @gpl # install the latest BtBN gpl build of FFmpeg 7
ffdl install =7.0.2 # install the 7.0.2 release from johnvansickle.com or
# gyan.dev (excludes BtBN post release)
ffdl install snapshot@full # full build of latest snapshotLike pip, use -U or --upgrade flag
ffdl install -Uffdl uninstallThis package has the following useful attributes:
import ffmpeg_downloader as ffdl
ffdl.ffmpeg_dir # FFmpeg binaries directory
ffdl.ffmpeg_version # version string of the intalled FFmpeg
ffdl.ffmpeg_path # full path of the FFmpeg binary
ffdl.ffprobe_path # full path of the FFprobe binary
ffdl.ffplay_path # full path of the FFplay binaryThe ffxxx_path attributes are useful to call FFxxx command with subprocess:
# To call FFmpeg via subprocess
import subprocess as sp
sp.run([ffdl.ffmpeg_path, '-i', 'input.mp4', 'output.mkv'])Meanwhile, there are many FFmpeg wrapper packages which do not let you specify the
FFmpeg path or cumbersome to do so. If installing the FFmpeg with --add-path option is
not preferable, use ffmpeg_downloader.add_path() function to make the binaries available
to these packages.