Skip to main content

A powerful TUI tool to interactively select and remux audio/subtitle tracks from video files

Project description

TrackRemux

TrackRemux is a powerful Terminal User Interface (TUI) tool designed to help you clean up your video library. It allows you to interactively specify audio and subtitle tracks from your video files and remux them into clean, optimized containers without re-encoding the video stream.

This whole project was vibe coded on a Friday evening out of necessity while organizing the media library on my NAS.

Media Browser

[!TIP] Check out the CHANGELOG to see what's new in the latest version!

🚀 Purpose

Modern media often comes with a bloat of unnecessary tracks - commentary audio, multiple languages you don't speak, or dozens of subtitle formats. TrackRemux simplifies the process of removing this clutter.

TrackRemux Demo

This not only saves significant disk space but also prevents the confusion and inconvenience of managing tracks in media players (like those on Smart TVs or mobile devices) where selecting the right audio or subtitle stream can be cumbersome or even impossible.

Instead of wrestling with complex ffmpeg command-line arguments for every single file, TrackRemux provides a visual interface to:

  1. Scan directories for video files.
  2. Select exactly which tracks you want to keep.
  3. Remux the file efficiently (Direct Stream Copy).

✨ Features

  • Interactive TUI: Built with curses for a fast, keyboard-centric workflow.
  • Batch Processing: Automatically detects and processes TV shows/series/collections sequentially.
    • Smart Detection: Recognizes series patterns (S01E01, 1x01, Ep01) and groups by season.
    • Structural Fingerprinting: Groups files with identical track structure.
    • Unified Editing: Edit one file, apply changes to all files in the batch.
  • Rich Meta-data Explorer:
    • Displays file sizes, track counts, and audio languages at a glance.
    • Visual Status Indicators: Instantly spot files that have already been converted (Green size) or are currently processing (Dim Yellow).
    • Folder Navigation: Browse nested directory structures (Enter to open, Esc to go back).
  • Deep Track Inspection:
    • Track Reordering: Move tracks up/down with Shift+Arrow keys to set their index in the final file.
    • External Tracks: Automatically detects and integrates external audio/subtitle files (even in Audio/ or Subs/ subfolders).
    • Language Management: Guesses 30+ languages from filenames (e.g. dut.srt) or supports manual setting via the [L] key.
    • Smart Matching: Automatically detects existing conversions and restores your previous track selections.
  • Preview Capabilities: Listen to audio tracks directly from the TUI (macOS afplay integration) to confirm contents before keeping them.
  • Intelligent Output Management:
    • Three Output Modes: Choose between [O]verwrite (atomic in-place replacement), [L]ocal (save converted_* to CWD), or [R]emote (save converted_* next to source files).
    • Smart Batch Output: Batch conversions automatically create a converted_<directory>/ folder with original filenames preserved, instead of prefixing every file.
    • NAS-Safe Atomic Swaps: Overwrites are safely processed in a hidden .trackremux_staging/ directory and shifted via instantaneous atomic swaps to avoid media server race conditions, keeping original files safely in .trackremux_trash/ for recovery.
    • Read-Only Detection: Automatically warns when the source filesystem is read-only, preventing failed Overwrite/Remote saves.
  • Intelligent Audio Fallbacks (DTS/TrueHD → EAC3/AC3):
    • Automatically transcode high-bitrate incompatible formats (DTS-HD MA, TrueHD, DTS) down to universally compatible EAC3 5.1 (1024kbps) or AC3 640k via the [C] hotkey.
    • Features a robust encoding safety net: if your version of ffmpeg encounters layout limitations (e.g. failing to encode 7.1 to EAC3), it automatically catches the failure and falls back to the next-best conversion format without breaking the batch.
    • Features a dynamic DTS>AC3 badge directly inside the Explorer file list tracking conditionally encoded native AC3 streams.
    • Added [D] hotkey to explicitly filter media list views exclusively to files with DTS-encoded formats.
  • Smart Configurations & Profiles:
    • Build and utilize default setting profiles (keep_langs, discard_langs, ac3 preference overrides).
    • Interactive profile editor overlay via [P] — Enter to edit fields, cursor navigation, Enter to confirm and auto-save, Escape to discard changes.
    • Profiles can be intelligently evaluated and interactively applied with [A] across matches to dramatically accelerate repetitive multi-file adjustments.
  • Safe Conversion:
    • Uses ffmpeg for robust processing.
    • Identifies edited assets automatically tracking changes reliably even across format shifts with its own .mkv metadata tag system: trackremux_id.
    • Real-time accurate progress tracking based on frame ratios rather than arbitrary byte streams, complete with dynamically recalculated size reduction estimates during audio transcoding.

📸 Visual Walkthrough

1. Launch & Directory Scan

Scan any folder to instantly see track counts and sizes. Launch

2. Intelligent Track Selection

Pick exactly what you need. Audio previews help distinguish between different dubs or commentaries. Selecting Tracks

3. External Tracks & Language Editing

TrackRemux finds external subtitle/audio files automatically. You can also manually correct missing language tags. External Tracks

4. Fast, Lossless Conversion

Watch the progress in real-time as ffmpeg remuxes your file at disk-IO speeds. Converting

5. Successful Completion

Final sizes and success messages are displayed directly in the TUI upon completion. Result

6. Efficient Storage

Remuxing is lossless and fast. You can see the significant size savings in your directory listing without any quality loss. Result Difference

🛠️ Prerequisites

  • Python 3.10+
  • FFmpeg must be installed and accessible in your system PATH.
    • macOS: brew install ffmpeg

📦 Installation & Setup

Option 1: Install as a Global Tool (Recommended)

The easiest way to use TrackRemux is to install it globally using uv:

uv tool install trackremux

Once installed, you can simply run trackremux from any directory.

Option 2: Running from Source

If you prefer to run it directly from the repository:

  1. Clone the repository:

    git clone https://github.com/antimirov/trackremux.git
    cd trackremux
    
  2. Run using the wrapper:

    python3 trackremux.py /path/to/media
    
  3. Run as a module:

    python3 -m trackremux /path/to/media
    
  4. Using uv (for development):

    uv sync
    uv run trackremux /path/to/media
    

🖥️ Usage

You can point TrackRemux to a directory (Explorer Mode) or a specific video file (Editor Mode).

Explorer Mode (Directory)

Browse and process your entire library:

trackremux /path/to/your/movies

Single File Mode

Jump straight into the track editor for a specific file:

trackremux "My Movie.mkv"

⌨️ Keyboard Controls

File Explorer

Key Action
↑ / ↓ Navigate file list
PgUp / PgDn Scroll pages
Enter Open selected file in Editor
B Open Batch Selector (when batches detected)
D Toggle Filter: All / DTS only
M Toggle Mouse Support
R Force re-scan current directory
N / S / T / A Sort by Name, Size, Tracks, Audio Size
Q / Esc Quit Application
Ctrl+C Force Quit instantly

Track Editor

Key Action
Space Toggle Track (Keep/Discard)
Enter Preview Track (Audio only)
← / → Seek in preview
↑ / ↓ Navigate Tracks
Shift+↑ / ↓ Move selected track UP / DOWN
L Set Language (manual edit)
C Toggle DTS → AC3 audio conditioning
P Open Profile editor (keep/discard languages, AC3 preference)
A Apply saved profile to current file
M Toggle Mouse Support
S Save — opens output mode dialog ([O]verwrite / [L]ocal / [R]emote)
Esc / Q Back to Explorer

🗺️ Roadmap

See ROADMAP.md for the full feature roadmap. Highlights:

  • Batch Processing — Completed in v0.6.0
  • In-Place Saving — Overwrite / Local / Remote output modes — Completed in v0.7.0
  • Audio Conditioning — Flatten DTS-HD / TrueHD to AC3 for universal playback — Completed in v0.7.0
  • Smart Defaults — Auto-select tracks based on language config profiles — Completed in v0.7.0
  • Track Metadata — Edit titles, set default/forced disposition flags
  • 🧊 Dry Run / Export — Generate .sh scripts for remote NAS execution

📝 License

MIT License. See LICENSE for more details.

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

trackremux-0.8.1.tar.gz (57.1 kB view details)

Uploaded Source

Built Distribution

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

trackremux-0.8.1-py3-none-any.whl (59.7 kB view details)

Uploaded Python 3

File details

Details for the file trackremux-0.8.1.tar.gz.

File metadata

  • Download URL: trackremux-0.8.1.tar.gz
  • Upload date:
  • Size: 57.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.7 {"installer":{"name":"uv","version":"0.10.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for trackremux-0.8.1.tar.gz
Algorithm Hash digest
SHA256 7700db164af9ff348565415caad8e24ce92138f07ca9e0098a530a92347dd2d8
MD5 d51e916d15024707479451743fb49b38
BLAKE2b-256 45ba31c77ccbbc2867dde2154dfe6cc82fbda4f10fb28d0195e0cae341b02a80

See more details on using hashes here.

File details

Details for the file trackremux-0.8.1-py3-none-any.whl.

File metadata

  • Download URL: trackremux-0.8.1-py3-none-any.whl
  • Upload date:
  • Size: 59.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.7 {"installer":{"name":"uv","version":"0.10.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for trackremux-0.8.1-py3-none-any.whl
Algorithm Hash digest
SHA256 8bc65ec9eff68b75ac60ce875a286e43dcff323d546ce0557fa87f9c2f75fad0
MD5 090cdc84c7014f0030c9c608a119d907
BLAKE2b-256 06f9ec20fc983a44e30018353e1c967b744a13baf556c60ec7e001cd88f5dce7

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