Video reduction tool
Project description
Video Encoder Utility
Overview
jelly_coder scans a folder for supported videos (.mkv, .mp4, .wmv, .mwv, .avi, .webm) and re-encodes them with size-aware defaults. It keeps subtitles/metadata, flips containers when MP4 constraints are violated, and preserves a mirrored directory tree when you choose not to overwrite in place.
Key capabilities:
- Automatic encoder selection with hardware-first preference (NVENC → QSV → AMF → x264) and explicit backend override flags.
- Height presets (
auto,1080p,720p,480p,360p) with bitrate scaling so smaller outputs also shrink file size. - Smart audio handling: copies compatible streams, forces stereo when sources are mono or pseudo-mono (e.g., WMV files with only one active channel), and warns about downmixing.
- Hardware fallbacks: if a chosen hardware encoder fails to create a session, the tool transparently repeats the job with
libx264so the batch continues.
Prerequisites
- Windows PowerShell 5.1 (default shell for the repo scripts).
- Python 3.11+ with virtual environment support.
- ffmpeg and ffprobe in
PATH.- Hardware backends require vendor drivers and an ffmpeg build with NVENC/QSV/AMF enabled.
Installation
python -m venv .venv
.\.venv\Scripts\Activate.ps1
pip install --upgrade pip
pip install -e .
Usage
# Show CLI help
python -m jelly_coder --help
# Reduce a folder, mirror outputs under ./output/<dir>, auto-select backend
python -m jelly_coder --input D:\media --quality 720p
# Force Intel QSV, enable overwrite, run at debug verbosity
python -m jelly_coder --input D:\media --encoder-backend qsv --overwrite --log-level debug
# Legacy wrapper remains available
python encode_videos.py --input D:\media
Key Flags
--input PATH: Directory scanned recursively for supported video extensions.--encoder-backend BACKEND:auto(default),nvenc,x264,qsv, oramf.--preferred-codec CODEC: Hinth264orhevc; respected when the backend supports it.--quality PRESET: Downscale preset (auto,1080p,720p,480p,360p).--workers N: Concurrent encodes (default 1; hardware encoders generally behave best at 1).--overwrite: Replace sources in place. When omitted, outputs land in./output/<input-folder>.--log-level LEVEL:info(default),debug,warning, etc.
Output Behavior
- MP4 targets convert SubRip/ASS to
mov_textautomatically; incompatible streams trigger a fallback to MKV. - Attached artwork, metadata, and subtitle tracks are propagated.
- When the output is larger than the input, a warning is emitted so you can review or delete the file.
- Audio streams are copied when safe; otherwise they are re-encoded to AAC 192k stereo, duplicating the dominant channel if the source is effectively mono.
Encoder Backends
- Auto: Queries ffmpeg encoders and picks the best available hardware backend (NVENC → QSV → AMF → x264).
- NVENC/QSV/AMF: Uses vendor hardware. Hardware decode fallbacks are attempted before giving up.
- x264: Software-only; always available.
- If a hardware backend exhausts its attempts (e.g.,
Error creating a MFX session: -9on QSV), the utility logs a warning and re-runs the encode withlibx264automatically.
Audio Handling
- ffprobe insights drive copy-or-transcode decisions.
- WMV inputs and other stereo tracks with severe channel imbalance trigger a sampling step; if only one channel has meaningful signal, the tool duplicates it so the result plays on both speakers.
- Mono and surround sources are converted to stereo with informative log messages about the change.
Development
- Run
python -m pytestandflake8before committing; coverage is enforced at 100%. python -m jelly_coder --helpverifies CLI wiring after refactors.- VS Code launchers in
.vscode/launch.jsonprovide ready-to-run debug sessions.
Troubleshooting
- Validate ffmpeg exposes the expected encoders:
ffmpeg -hide_banner -encoders | Select-String nvenc. - Hardware backends may need up-to-date GPU/Media drivers; keep Windows and vendor packages current.
- Delete partial outputs in
output/if you want to re-run without--overwrite.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file jellycoder-1.1.0.tar.gz.
File metadata
- Download URL: jellycoder-1.1.0.tar.gz
- Upload date:
- Size: 64.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
307b9c2a90c73e38cc20d63530cf279fa06435fa0a196812bfc51efce4c9b734
|
|
| MD5 |
ed3125b027cb5cd564445902b091eac0
|
|
| BLAKE2b-256 |
9fc56d4df88892fbd0d0b0ac4ab1dba98653791f5f77227fb5f9dc7d1716dd93
|
File details
Details for the file jellycoder-1.1.0-py3-none-any.whl.
File metadata
- Download URL: jellycoder-1.1.0-py3-none-any.whl
- Upload date:
- Size: 41.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5dd1dc12314856d59f38a2cf437911605802f4fd6501d87ac2b80df1ad5354a1
|
|
| MD5 |
5bf6f7b34bdfed9e4461015b6f7d0a8e
|
|
| BLAKE2b-256 |
6d149166f0d3bf9014034983517d57e83cf86daebf1bdfa15756027fafafd7b3
|