Skip to main content

Tools to transcode, inspect and convert videos.

Project description

Vid Cleaner

Changelog PyPI version PyPI - Python Version Tests codecov

Tools to transcode, inspect and convert videos. This package provides convenience wrappers around ffmpeg and ffprobe to make it easier to work with video files. The functionality is highly customized to my personal workflows and needs. I am sharing it in case it is useful to others.

Features

  • Remove commentary tracks and subtitles
  • Remove unwanted audio and subtitle tracks
  • Integrate with TMDb and Radarr/Sonarr to determine languages of videos
  • Convert to H.265 or VP9
  • Convert 4k to 1080p
  • Downmix from surround to create missing stereo streams with custom filters to improve quality
  • Remove unwanted audio and subtitle tracks, optionally keeping the original language audio track
  • Create clips from a video file
  • Search for video files under a directory that match specific criteria

Install

Before installing vid-cleaner, the following dependencies must be installed:

To install vid-cleaner, run:

# With uv
uv tool install vid-cleaner

# With pip
python -m pip install --user vid-cleaner

Usage

Run vidcleaner --help to see the available commands and options.

Configuration

Defaults for vid-cleaner are set in the configuration file located at ~/.config/vid-cleaner/config.toml. When vid-cleaner is run, it will create this file if it does not exist. All options can be overridden on the command line.

If you've updated your user config file, the flags for the cli will work in reverse order. For example, if you've set downmix_stereo = true in your user config file, the flag --downmix will actually disable downmixing.

Important: Vid-cleaner makes decisions about which audio and subtitle tracks to keep based on the original language of the video. This is determined by querying the TMDb, Radarr, andSonarr APIs. To use this functionality, you must add the appropriate API keys to the configuration file.

# Languages to keep (list of ISO 639-1 codes)
langs_to_keep = ["en"]

# Keep subtitles matching the local language(s) even when the audio is not in the local language(s)
keep_local_subtitles = false

# Keep commentary audio
keep_commentary = false

# Force dropping local subtitles even if audio is not default language
drop_local_subs = false

# Keep all subtitles
keep_all_subtitles = false

# Drop original language audio if not specified in langs_to_keep
drop_original_audio = false

# Always create a stereo track
downmix_stereo = false

# Save the video after each step (default is to save after all steps are completed)
save_each_step = false

# External services used to determine the original language of a movie or TV show
radarr_api_key = ""
radarr_url     = ""
sonarr_api_key = ""
sonarr_url     = ""
tmdb_api_key   = ""

File Locations

Vid-cleaner uses the XDG specification for determining the locations of configuration files, logs, and caches.

  • Configuration file: ~/.config/vid-cleaner/config.toml
  • Cache: ~/.cache/vid-cleaner

Contributing

See CONTRIBUTING.md for more information.

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

vid_cleaner-0.5.0.tar.gz (109.7 kB view details)

Uploaded Source

Built Distribution

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

vid_cleaner-0.5.0-py3-none-any.whl (54.5 kB view details)

Uploaded Python 3

File details

Details for the file vid_cleaner-0.5.0.tar.gz.

File metadata

  • Download URL: vid_cleaner-0.5.0.tar.gz
  • Upload date:
  • Size: 109.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.13

File hashes

Hashes for vid_cleaner-0.5.0.tar.gz
Algorithm Hash digest
SHA256 60cd3a40d6b0b9931f8aa5e90ab297ec714fbb09ccfc768a6c90907bc27e32cb
MD5 8bb4a5cf9f9cd986a9f1525da934999f
BLAKE2b-256 459caa68c40b1f6fd3233460c165a3f30f6bd688fe418c5e1bbbbf41d6207cbe

See more details on using hashes here.

File details

Details for the file vid_cleaner-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: vid_cleaner-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 54.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.13

File hashes

Hashes for vid_cleaner-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c85dcd3d9993d5d6890daf29c80a53fba65782fb7396244efd0cbf3ea8b20ebf
MD5 249e6d297c5ecee61f7bc926f6b8feb3
BLAKE2b-256 bf73d7fa646f9ddcfe6ffaee352d19bb6d308447bd5ad0303f9f157b2fd17ec6

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