Skip to main content

Organize your digital media files

Project description

media-file-tools

Description

Media File Tools is a Python package designed to automate some of the tedious tasks of organizing your video files.

Features

  • Bulk rename TV series episodes that have undescriptive names.
  • Create a TV show database with episode title, air date and plot summary.
  • Create a movies database organized alphabetically or by folder.
  • Find duplicate music files.
  • Uses BeautifulSoup4 and Cinemagoer to scrape data from IMDB.

Installation

You can install media-file-tools using pip:

pip install media-file-tools

How to use

To create a csv file with the seasons, titles and plot summaries of a TV series:

from mediafiletools import make_seriesdb

make_seriesdb(imdb_id='tt0098904')

To overwrite the old file names of the show on your disc with the ones one the csv file:

from mediafiletools import rename_episodes

rename_episodes('C:\Users\user\Videos\Seinfeld', csv_path='C:\Users\user\episodes.csv')

Use caution with this command. Right now, this only looks for folders titled 'Season 1', 'Season 2', 'Season 3' etc. Any folders not following this naming convention will be skipped. The names of the files before and after they're renamed are recorded in a log.

To get the episodes and write the file names in one command, pass the imdb_id as a keyword to rename_episodes:

rename_episodes('C:\Users\user\Videos\Seinfeld', imdb_id='tt0098904')

Sometimes the episodes on IMDB are in a different order or have episode 0/unaired pilots not on a DVD or BlueRay. Make sure the episodes list lines up perfectly with the ones on your disc.

To specify which season(s) to get, pass the season numbers as the start and end keywords:

make_seriesdb(imdb_id='tt0098904', start=3, end=6)

To create an organized movie database from every movie file in the directory:

from mediafiletools import make_moviedb

make_moviedb('C:\Users\user\Movies')

Calling with no arguments will sort the movies alphabetically by default. To organize movies by folder instead, use the sort_type keyword:

make_moviedb('C:\Users\user\Movies', sort_type='folder')

To clean up the filenames, use the strip keyword:

make_moviedb('C:\Users\user\Movies', sort_type='folder', strip=True)

This will remove extraneous text from the filename. e.g. Double.Down.2005.DVDRip.x264.mkv will be written as: Double Down 2005

To find duplicate music files:

from mediafiletools import find_music_dupes

find_music_dupes(r'C:/Users/user/Music')

To output to the console or a text file instead of a csv, use the output_type keyword:

make_moviedb('C:\Users\user\Movies', output_type='txt')

Supported keywords are csv, txt and console.

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_file_tools-1.1.1.tar.gz (21.2 kB view details)

Uploaded Source

Built Distribution

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

media_file_tools-1.1.1-py3-none-any.whl (16.4 kB view details)

Uploaded Python 3

File details

Details for the file media_file_tools-1.1.1.tar.gz.

File metadata

  • Download URL: media_file_tools-1.1.1.tar.gz
  • Upload date:
  • Size: 21.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.0 CPython/3.12.2

File hashes

Hashes for media_file_tools-1.1.1.tar.gz
Algorithm Hash digest
SHA256 752e04a65273d05b9e80e230a038fffa1ac56f467f27ce86806eae9a48b0cbf4
MD5 db5886f338f4dcd3d0832341af8b038a
BLAKE2b-256 a32826854b6640407faaeb035d44b46a8c641be5577b63d792127208b590ea2f

See more details on using hashes here.

File details

Details for the file media_file_tools-1.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for media_file_tools-1.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 924252685888e39b9adae706c61da9f68268265f0626995343f7cea35914beca
MD5 704bec2566f0473336bbafbf162d43e7
BLAKE2b-256 01eb7c19671e71c9598d2edc3e449e08e4d2b99f827c8f2e17122f024f282bec

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