Skip to main content

A cosmetic treatment for your media files: movies, tv shows and also their subtitles.

Project description

Medicure

Medicure is a cosmetic treatment for your media files: movies, tv shows and also their subtitles. Medicure provides a command-line tool and also a Python package for you.

Name

The word medicure is combination of media and the Latin word cura which means "care".

Requirements

  • TMDB API Key: Medicure uses TMDB's API to get correct info for movies and tv shows. So you need to create a TMDB account and generate an API key inorder to use Medicure.
  • Mediainfo: Medicure requires Mediainfo to extract track info from video and audio files.
  • MKVToolNix: Medicure uses mkvmerge to craete new treated media files. mkvmerge is one of the MKVToolNix's command-line tools

Installation

The easiest way to install is from PyPI:

pip install medicure

Alternatively, you can install directly from GitHub:

pip install git+https://github.com/alirezatheh/medicure.git

Simple Example

In this example we want to treat video files of Season 6 of the famous tv show Peaky Blinders downloaded from PSArips.

First we search the name of tv show in TMDB to see season names. In this case season name starts with Series. In our tv shows directory we create Peaky Blinders/Series 6 directory and put the files there. directory structure will look like this:

TV Shows
└── Peaky Blinders
    └── Series 6
        ├── Peaky.Blinders.S06E01.1080p.10bit.WEB-DL.x265.HEVC.PSA.AM.mkv
        ├── Peaky.Blinders.S06E02.INTERNAL.1080p.10bit.WEB-DL.x265.PSA.AM.mkv
        ├── Peaky.Blinders.S06E03.INTERNAL.1080p.10bit.WEB-DL.x265.PSA.AM.mkv
        ├── Peaky.Blinders.S06E04.1080p.10bit.WEB-DL.x265.PSA.AM.mkv
        ├── Peaky.Blinders.S06E05.INTERNAL.1080p.10bit.WEB-DL.x265.PSA.AM.mkv
        └── Peaky.Blinders.S06E06.1080p.10bit.WEB-DL.x265.PSA.AM.mkv

And each file has the following track infos:

Type Title Language Default Forced
Video Undetermined Yes No
Audio English Yes No
Subtitle English Yes No

Then we run following python script:

from pathlib import Path

from medicure import Medicure, DubbingSupplier

# In this we only one dubbing supplier and that's which contains
# original audio and subtitle.
dubbing_suppliers = [
    DubbingSupplier(
        # For original dubbing supplier name doesn't matter.
        name='original',
        audio_language_code='eng',
        subtitle_language_code='eng',
        correct_language_code='eng',
        audio_search_pattern=None,
        subtitle_search_pattern=None,
        file_id=0,
    ),
]

file_search_pattern_to_id = {
    # We have only one file for each episode that can be found by this
    # pattern.
    'PSA': 0,
}
medicure = Medicure(
    tmdb_api_key='YOUR_TMDB_API_KEY',
    tvshows_directory=Path('path/to/tvshows_directory'),
)
medicure.treat_media(
    # You can find this in url of tv show in imdb.
    imdb_id='tt2442560',
    file_search_pattern_to_id=file_search_pattern_to_id,
    video_language_code='eng',
    video_source='PSA',
    video_release_format='WEB-DL',
    dubbing_suppliers=dubbing_suppliers,
    season_number=6,
)

Then directory structure will look like this:

TV Shows
└── Peaky Blinders
    ├── Series 6
       ├── Peaky.Blinders.S06E01.1080p.10bit.WEB-DL.x265.HEVC.PSA.AM.mkv
       ├── Peaky.Blinders.S06E02.INTERNAL.1080p.10bit.WEB-DL.x265.PSA.AM.mkv
       ├── Peaky.Blinders.S06E03.INTERNAL.1080p.10bit.WEB-DL.x265.PSA.AM.mkv
       ├── Peaky.Blinders.S06E04.1080p.10bit.WEB-DL.x265.PSA.AM.mkv
       ├── Peaky.Blinders.S06E05.INTERNAL.1080p.10bit.WEB-DL.x265.PSA.AM.mkv
       └── Peaky.Blinders.S06E06.1080p.10bit.WEB-DL.x265.PSA.AM.mkv
    └── Series 6 Edited
        ├── Peaky Blinders - S06E01 - Black Day.mkv
        ├── Peaky Blinders - S06E02 - Black Shirt.mkv
        ├── Peaky Blinders - S06E03 - Gold.mkv
        ├── Peaky Blinders - S06E04 - Sapphire.mkv
        ├── Peaky Blinders - S06E05 - The Road to Hell.mkv
        └── Peaky Blinders - S06E06 - Lock and Key.mkv

And each file track info:

Type Title Language Default Forced
Video PSA WEB-DL English Yes No
Audio English Yes No
Subtitle English No No

More in depth examples will be coming soon with Medicure's documentation.

Command-line Interface

Let's treat the above example using Medicure's command-line interface.

Since we're using CLI for the first time, we need to save our TMDB API key and tv shows directory locally:

medicure save tmdb-info YOUR_TMDB_API_KEY
medicure save collection-info \
    --tvshows-directory PATH_TO_YOUR_TVSHOWS_DRIECTORY

Now we can run:

medicure treat media \
    tt2442560 \
    '{"PSA": 0}' \
    eng \
    PSA \
    WEB-DL \
    '[["original", "eng", "eng", "eng", null, null, 0]]' \
    6

Directory Scanning

  • Tv Shows: As showed above Medicure expects following structure for your tv shows directory:
    {Your tv shows directory}
    └── {TV Show name on TMDB}
        └── {TV Show season name on TMDB}
            └── {Episde files}
    
  • Movies: And for movies directory Medicure expects:
    {You movies directory}
    └── {Movie name on TMDB} - {Movie release year}
        └── {Movie files}
    

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

medicure-0.0.4.tar.gz (15.2 kB view hashes)

Uploaded Source

Built Distribution

medicure-0.0.4-py3-none-any.whl (16.1 kB view hashes)

Uploaded Python 3

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