Skip to content

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

License

Notifications You must be signed in to change notification settings

simsekhalit/media-fixer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

1 Commit
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

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.


ℹ️ 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.