https://github.com/CrypticSignal/better-ffmpeg-progress
A Python package for running an FFmpeg command & showing better progress info - percentage progress, a progress bar and ETA.
https://github.com/CrypticSignal/better-ffmpeg-progress
bar eta ffmpeg ffprobe percentage process progress python python3 rich
Last synced: 2 months ago
JSON representation
A Python package for running an FFmpeg command & showing better progress info - percentage progress, a progress bar and ETA.
- Host: GitHub
- URL: https://github.com/CrypticSignal/better-ffmpeg-progress
- Owner: CrypticSignal
- License: mit
- Created: 2021-09-19T15:23:48.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2025-02-27T17:34:04.000Z (3 months ago)
- Last Synced: 2025-03-28T20:07:45.158Z (2 months ago)
- Topics: bar, eta, ffmpeg, ffprobe, percentage, process, progress, python, python3, rich
- Language: Python
- Homepage: https://pypi.org/project/better-ffmpeg-progress
- Size: 152 KB
- Stars: 60
- Watchers: 1
- Forks: 16
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
[](https://pypistats.org/packages/better-ffmpeg-progress)
[](https://pypistats.org/packages/better-ffmpeg-progress)

[](LICENSE.txt)# Better FFmpeg Progress
Runs an FFmpeg command and shows a progress bar with percentage progress, time elapsed and ETA.The [Rich](https://github.com/Textualize/rich) library is used for the progress bar by default, [tqdm](https://github.com/tqdm/tqdm) will be used if you pass `use_tqdm=True` to the `run` method.
FFmpeg outputs something like:
```
frame= 692 fps= 58 q=28.0 size= 5376KiB time=00:00:28.77 bitrate=1530.3kbits/s speed=2.43x
```
Better FFmpeg Progress outputs something like:
```
⠏ Processing abc.webm ━━━━━━━━━╺━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 23% 0:00:04 00:15
```
Where:
- `Processing abc.webm` is the description of the progresss bar.
- `23%` is the percentage progress.
- `0:00:04` is the time elapsed.
- `00:15` is the estimated time until the FFmpeg process completes.As you can see, the output of Better FFmpeg Progress is much more useful.
## Installation
```
pip install better-ffmpeg-progress --upgrade
```## Usage
Create an instance of the `FfmpegProcess` class and supply a list of arguments like you would to `subprocess.run()` or `subprocess.Popen()`.Here's a simple example:
```py
from better_ffmpeg_progress import FfmpegProcessprocess = FfmpegProcess(["ffmpeg", "-i", "input.mp4", "-c:v", "libx265", "output.mp4"])
# return_code will be 0 if the process completed successfully, otherwise it will be 1
return_code = process.run()
```
## Optional Arguments
An instance of the `FfmpegProcess` class takes the following **optional** arguments:- `ffmpeg_log_level` - Desired FFmpeg log level. Default: `"verbose"`
- `ffmpeg_log_file` - The filepath to save the FFmpeg log to. Default: `_log.txt`
- `print_detected_duration` - Print the detected duration of the input file. Default: `False`
- `print_stderr_new_line` - If better progress information cannot be shown, print FFmpeg stderr in a new line instead of replacing the current line in the terminal. Default: `False`The `run` method takes the following **optional** arguments:
- `print_command` - Print the FFmpeg command being executed. Default: `False`
- `use_tqdm` - Use [tqdm](https://github.com/tqdm/tqdm) instead of [Rich](https://github.com/Textualize/rich) for the progress bar. Default: `False`