Skip to main content

Video reduction tool

Project description

Video Encoder Utility

PyPI - Version Python package

Overview

jelly_coder scans a folder for supported videos (.mkv, .mp4, .wmv, .mwv, .avi) 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 libx264 so 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, or amf.
  • --preferred-codec CODEC: Hint h264 or hevc; 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_text automatically; 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: -9 on QSV), the utility logs a warning and re-runs the encode with libx264 automatically.

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 pytest and flake8 before committing; coverage is enforced at 100%.
  • python -m jelly_coder --help verifies CLI wiring after refactors.
  • VS Code launchers in .vscode/launch.json provide 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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

jellycoder-1.0.0.tar.gz (64.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

jellycoder-1.0.0-py3-none-any.whl (41.5 kB view details)

Uploaded Python 3

File details

Details for the file jellycoder-1.0.0.tar.gz.

File metadata

  • Download URL: jellycoder-1.0.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

Hashes for jellycoder-1.0.0.tar.gz
Algorithm Hash digest
SHA256 533a7cb14103420d97e27daa596cf58c3341467f175256d65c46044a1c12b04a
MD5 95e1d14e9fcf2055d581335efcf45324
BLAKE2b-256 73e98ce0af05631da14b9e0e641d75ac8c6322aa67c2b72c22599e2dded3fa3f

See more details on using hashes here.

File details

Details for the file jellycoder-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: jellycoder-1.0.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

Hashes for jellycoder-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8eec75a203b60a20309fb7d3566836544ab3364b72018d3b1330cdcc865faa05
MD5 48fcc47417774002e57006f0b7fe782d
BLAKE2b-256 114e7740e3209ebd266691de90eef52272879e241f9f59d90d006f831e303e77

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page