Skip to main content

transcoder FFmpeg based wrapper

Project description

tabarnak - transcoder FFmpeg based utility tool

Port au Persil

Build Status Pylint codecov

Description

In the Province of Québec tabarnak is a swear derived from the tabernacle but it is an acronym for:

Transcoder All Basically Accessible Resolutely Not All Klingon

Le tact dans l'audace, c'est de savoir jusqu'où on peut aller trop loin.

Jean Cocteau

This script is used to convert video or audio media files to modern codecs such as HEVC, VP9, AV1 (experimental) or Opus. It walks into a directory and probes media files for video or audio that are not encoded with specified codec (default HEVC). Then it transcodes them. The idea is to use a more modern codec that has a better quality/bitrate ratio. Resulting files are significantly smaller than original h264, mpeg2, mpeg4 or likely any other formats that they are currently encoded to.

tabarnak uses crf encoding. All channels are copied. The audio is converted by ffmpeg to ogg vorbis by default.

tabarnak won’t delete or clean up your files. It will skip files that are already done. Basic sanity check is performed after encoding and it will print a warning if the input and output size do not match.

If you plan to use your media files with a chrome cast, be sure the buy chromecast ultra since the 3rd generation chromecast does not support HEVC.

Features

  • Easy to use out of the box
    • input & output directory support
    • keep relative path option for transcoding entire hierarchy of media files
    • copy your metadata (default) or not
  • Basic default configuration for basic codecs such as h264, hevc, vp9 & opus
  • Custom configuration workflow using either json or yaml
  • Configurable logging including basic prometheus support
  • Transcoder stats output (yaml)
  • Automatic tests

Usage

Install

pip3 install tabarnak-desjare

Getting help

For help: tabarnak -h

Example usage

transcode all media files recursively using h264 codec and output them to the output directory

tabarnak --input-dir . --output-dir output --h264

transcode your entire music library recursively using opus codec in ogg container while keeping your directory structure and copy non media files

tabarnak --copy --opus --keep-relative-path --map-args "-map 0:0 " --output-dir your_output_dir

Note that the mapping argument is necessary since iTunes files may contain unwanted tracks that prevent files to be recognised by music players.

Requirements

I prepared a tutorial video to learn how to do that on Windows 10: https://gist.github.com/desjare/adc1514d46bcb38414a5e2a602f6d12d

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

tabarnak-desjare-0.0.7.tar.gz (16.4 kB view details)

Uploaded Source

Built Distribution

tabarnak_desjare-0.0.7-py3-none-any.whl (27.2 kB view details)

Uploaded Python 3

File details

Details for the file tabarnak-desjare-0.0.7.tar.gz.

File metadata

  • Download URL: tabarnak-desjare-0.0.7.tar.gz
  • Upload date:
  • Size: 16.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.55.0 CPython/3.7.9

File hashes

Hashes for tabarnak-desjare-0.0.7.tar.gz
Algorithm Hash digest
SHA256 cd913f7fde33bf6ce3dea7d9f9473daab7643b92ceea19d9d7dcc424709c3934
MD5 59ee517b6c240bca067b8d5ddcdfd4f0
BLAKE2b-256 fa0a99753d821f4de3960c2fb05155859cc4cb9fb09f61be1cc107415e80d8e1

See more details on using hashes here.

File details

Details for the file tabarnak_desjare-0.0.7-py3-none-any.whl.

File metadata

  • Download URL: tabarnak_desjare-0.0.7-py3-none-any.whl
  • Upload date:
  • Size: 27.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.55.0 CPython/3.7.9

File hashes

Hashes for tabarnak_desjare-0.0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 e0cff2b505cd597e871efedf219b489cf8a376422393dbe822b5f3688f74389c
MD5 515a6b652985e3bb37abba2a61215c23
BLAKE2b-256 c99010ca19a7e87f11e6430f023caa862cf39f397f304799a075e77fe369c054

See more details on using hashes here.

Supported by

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