Skip to main content

A wrapper around ffmpeg to make it work in a concurrent and memory-buffered fashion.

Project description

Media Fixer

Have you ever had a film or TV show that your TV wasn't able to play its audio? Well this program is for you. Media Fixer is a program which converts given media to a playable format. It's a kind of wrapper for ffmpeg that works with multiple files in a concurrent & memory-buffered fashion.

Requirements

Python >= 3.8 is required. (CPython and PyPy are both supported)

Additionally ffmpeg and mediainfo are required for this program to run. They can be installed on Ubuntu as the following way:

sudo apt install ffmpeg mediainfo

Installation

Media fixer can be either installed directly via pip:

pip install media-fixer

Or it can be installed from the source:

git clone https://github.com/simsekhalit/media-fixer.git
python3 -m pip install ./media-fixer

Manual

$ python3 -m media_fixer --help
usage: media-fixer [-h] [--audio AUDIO_STREAM] [--input-options INPUT_OPTIONS] [--max-memory MAX_MEMORY] [--output-options OUTPUT_OPTIONS] SOURCE [SOURCE ...] TARGET

A wrapper around ffmpeg to make it work in a concurrent and memory-buffered fashion.

positional arguments:
  SOURCE                source files/directories (works recursively)
  TARGET                target directory

optional arguments:
  -h, --help            show this help message and exit
  --audio AUDIO_STREAM  select index of audio stream to be used (zero-indexed). defaults to 0
  --input-options INPUT_OPTIONS
                        specify custom input file options for ffmpeg (overrides default ones)
  --max-memory MAX_MEMORY
                        specify allowed max memory usage as percent
  --output-options OUTPUT_OPTIONS
                        specify custom output file options for ffmpeg (overrides default ones)

For more information: https://github.com/simsekhalit/media-fixer

Media Fixer can be used in one of the two modes, namely Auto and Custom.

Auto Mode

If no output options are given, Media Fixer works in Auto mode. Initially, an audio stream is selected with --audio. For each given file, existing audio codec is detected and if it's in DTS format, it's converted to EAC-3. Otherwise, it's just copied to the target file as it is. While doing that only the selected audio stream is processed. Rest of the audio streams are stripped out. This is useful for saving space since generally there are many audio streams in a film (English, French, Spanish, etc.), but only one of them is needed.

Custom Mode

If output options are given with --output-options, Media Fixer works in custom mode. All the given files are converted according to given output options.

Examples

SOURCE and TARGET arguments are interpreted in the same way in both modes.
Single or multiple source paths can be given. For any given source path:
If it's a file, its corresponding target is written under the target path.
If it's a directory, then it's traversed recursively and all the files under it are processed. Source directory tree is generated as the same way in the target path. Corresponding target files are written accordingly.


:information_source: MediaInfo is a helpful tool for identifying audio streams and their formats. It can be downloaded from https://mediaarea.net/en/MediaInfo


1. There is a film and its 3rd audio (which is the audio stream with index 2) is chosen to be used:

python3 -m media_fixer --audio 2 '/mnt/HDD/Matrix 4.mkv' '/mnt/MyUSB'

Matrix 4.mkv is processed and the resulting file is written to /mnt/USB/Matrix 4.mkv


2. There is a folder which contains a season of a TV show:

/mnt/HDD/Brooklyn Nine-Nine Season 1
/mnt/HDD/Brooklyn Nine-Nine Season 1/S01E01.mkv
/mnt/HDD/Brooklyn Nine-Nine Season 1/S01E02.mkv
/mnt/HDD/Brooklyn Nine-Nine Season 1/S01E03.mkv
...

Following command is executed:

python3 -m media_fixer '/mnt/HDD/Brooklyn Nine-Nine Season 1' '/mnt/USB'

All the episodes are processed and written to /mnt/USB/Brooklyn Nine-Nine Season 1


3. Custom ffmpeg options wanted to be used:

python3 -m media_fixer --output-options '-c:v copy -c:a aac -c:s copy -f matroska -map 0:v -map 0:a:2 -map 0:s' '/mnt/HDD/Brooklyn Nine-Nine Season 1' '/mnt/USB'

Following ffmpeg command is run for each source file:

ffmpeg -i $source -c:v copy -c:a aac -c:s copy -f matroska -map 0:v -map 0:a:2 -map 0:s -y -

$source is replaced with the source file's path and output is captured from stdout, buffered there and then written to the corresponding target path.

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

media-fixer-1.0.0.tar.gz (11.7 kB view details)

Uploaded Source

Built Distribution

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

media_fixer-1.0.0-py3-none-any.whl (9.9 kB view details)

Uploaded Python 3

File details

Details for the file media-fixer-1.0.0.tar.gz.

File metadata

  • Download URL: media-fixer-1.0.0.tar.gz
  • Upload date:
  • Size: 11.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.10

File hashes

Hashes for media-fixer-1.0.0.tar.gz
Algorithm Hash digest
SHA256 dcb3b65511974482e3fa6acee0832ef60a57dce07854a76374e0463eb93cd39f
MD5 c387207c229423aa83c21640d8a3baee
BLAKE2b-256 a81e8c6a3c25de28ba73a79046c3f7041f367050326ca491c53fe25cd271fd83

See more details on using hashes here.

File details

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

File metadata

  • Download URL: media_fixer-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 9.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.10

File hashes

Hashes for media_fixer-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 aa518b9fb1146d7e5dc6991f9af87d9864b33de3c7dffe9b660c31481d5114a5
MD5 9f22b07f1638242630789bccbe0fb568
BLAKE2b-256 ca615904e1ca622e50ae3f6983906b127b07be0dc4b0479a4a160f83b904a5a1

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