Merge pull request #335 from JonnyWong16/feature/merge_multiepisodes

Fix `merge_multiepisode.py` renumbering episodes across seasons
This commit is contained in:
blacktwin 2022-04-06 11:58:03 -04:00 committed by GitHub
commit 3e1af802fa
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -11,10 +11,21 @@ Notes:
* Episode titles, summaries, and tags will be appended to the first episode of the group. * Episode titles, summaries, and tags will be appended to the first episode of the group.
* Without re-numbering will keep the episode number of the first episode of each group.
* Re-numbering starts at the first group episode's number and increments by one. Skipping numbers is not supported.
* e.g. s01e01-e02, s01e03, s01e04, s01e05-e06 --> s01e01, s01e02, s01e03, s01e04
* e.g. s02e05-e06, s01e07-e08, s02e09-e10 --> s02e05, s02e06, s02e07
* e.g. s03e01-e02, s03e04, s03e07-e08 --> s03e01, s03e02, s03e03 (s03e03, s03e05, so3e06 skipped)
* To revert the changes and split the episodes again, the show must be removed and re-added to Plex (aka Plex Dance). * To revert the changes and split the episodes again, the show must be removed and re-added to Plex (aka Plex Dance).
Usage: Usage:
* Without renumbering episodes:
python merge_multiepisodes.py --library "TV Shows" --show "SpongeBob SquarePants" python merge_multiepisodes.py --library "TV Shows" --show "SpongeBob SquarePants"
* With renumbering episodes:
python merge_multiepisodes.py --library "TV Shows" --show "SpongeBob SquarePants" --renumber
''' '''
import argparse import argparse
@ -33,17 +44,19 @@ PLEX_URL = os.getenv('PLEX_URL', PLEX_URL)
PLEX_TOKEN = os.getenv('PLEX_TOKEN', PLEX_TOKEN) PLEX_TOKEN = os.getenv('PLEX_TOKEN', PLEX_TOKEN)
def group_episodes(plex, library, show): def group_episodes(plex, library, show, renumber):
groups = defaultdict(list)
show = plex.library.section(library).get(show) show = plex.library.section(library).get(show)
for episode in show.episodes():
for season in show.seasons():
groups = defaultdict(list)
startIndex = None
for episode in season.episodes():
groups[episode.locations[0]].append(episode) groups[episode.locations[0]].append(episode)
if startIndex is None:
startIndex = episode.index
for index, (first, *episodes) in enumerate(groups.values()): for index, (first, *episodes) in enumerate(groups.values(), start=startIndex):
if not episodes:
continue
title = first.title + ' / ' title = first.title + ' / '
titleSort = first.titleSort + ' / ' titleSort = first.titleSort + ' / '
summary = first.summary + '\n\n' summary = first.summary + '\n\n'
@ -57,8 +70,13 @@ def group_episodes(plex, library, show):
writers.extend([writer.tag for writer in episode.writers]) writers.extend([writer.tag for writer in episode.writers])
directors.extend([director.tag for director in episode.directors]) directors.extend([director.tag for director in episode.directors])
if episodes:
merge(first, episodes) merge(first, episodes)
first.edit(**{
first.addWriter(writers, locked=True)
first.addDirector(directors, locked=True)
edits = {
'title.value': title[:-3], 'title.value': title[:-3],
'title.locked': 1, 'title.locked': 1,
'titleSort.value': titleSort[:-3], 'titleSort.value': titleSort[:-3],
@ -66,12 +84,14 @@ def group_episodes(plex, library, show):
'summary.value': summary[:-2], 'summary.value': summary[:-2],
'summary.locked': 1, 'summary.locked': 1,
'originallyAvailableAt.locked': 1, 'originallyAvailableAt.locked': 1,
'contentRating.locked': 1, 'contentRating.locked': 1
'index.value': index + 1, }
'index.locked': 1
}) if renumber:
first.addWriter(writers, locked=True) edits['index.value'] = index
first.addDirector(directors, locked=True) edits['index.locked'] = 1
first.edit(**edits)
def merge(first, episodes): def merge(first, episodes):
@ -83,6 +103,7 @@ if __name__ == '__main__':
parser = argparse.ArgumentParser() parser = argparse.ArgumentParser()
parser.add_argument('--library', required=True) parser.add_argument('--library', required=True)
parser.add_argument('--show', required=True) parser.add_argument('--show', required=True)
parser.add_argument('--renumber', action='store_true')
opts = parser.parse_args() opts = parser.parse_args()
plex = PlexServer(PLEX_URL, PLEX_TOKEN) plex = PlexServer(PLEX_URL, PLEX_TOKEN)