Merge pull request #335 from JonnyWong16/feature/merge_multiepisodes
Fix `merge_multiepisode.py` renumbering episodes across seasons
This commit is contained in:
commit
3e1af802fa
@ -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:
|
||||||
python merge_multiepisodes.py --library "TV Shows" --show "SpongeBob SquarePants"
|
* Without renumbering episodes:
|
||||||
|
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,45 +44,54 @@ 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():
|
|
||||||
groups[episode.locations[0]].append(episode)
|
|
||||||
|
|
||||||
for index, (first, *episodes) in enumerate(groups.values()):
|
for season in show.seasons():
|
||||||
if not episodes:
|
groups = defaultdict(list)
|
||||||
continue
|
startIndex = None
|
||||||
|
|
||||||
title = first.title + ' / '
|
for episode in season.episodes():
|
||||||
titleSort = first.titleSort + ' / '
|
groups[episode.locations[0]].append(episode)
|
||||||
summary = first.summary + '\n\n'
|
if startIndex is None:
|
||||||
writers = []
|
startIndex = episode.index
|
||||||
directors = []
|
|
||||||
|
|
||||||
for episode in episodes:
|
for index, (first, *episodes) in enumerate(groups.values(), start=startIndex):
|
||||||
title += episode.title + ' / '
|
title = first.title + ' / '
|
||||||
titleSort += episode.titleSort + ' / '
|
titleSort = first.titleSort + ' / '
|
||||||
summary += episode.summary + '\n\n'
|
summary = first.summary + '\n\n'
|
||||||
writers.extend([writer.tag for writer in episode.writers])
|
writers = []
|
||||||
directors.extend([director.tag for director in episode.directors])
|
directors = []
|
||||||
|
|
||||||
merge(first, episodes)
|
for episode in episodes:
|
||||||
first.edit(**{
|
title += episode.title + ' / '
|
||||||
'title.value': title[:-3],
|
titleSort += episode.titleSort + ' / '
|
||||||
'title.locked': 1,
|
summary += episode.summary + '\n\n'
|
||||||
'titleSort.value': titleSort[:-3],
|
writers.extend([writer.tag for writer in episode.writers])
|
||||||
'titleSort.locked': 1,
|
directors.extend([director.tag for director in episode.directors])
|
||||||
'summary.value': summary[:-2],
|
|
||||||
'summary.locked': 1,
|
if episodes:
|
||||||
'originallyAvailableAt.locked': 1,
|
merge(first, episodes)
|
||||||
'contentRating.locked': 1,
|
|
||||||
'index.value': index + 1,
|
first.addWriter(writers, locked=True)
|
||||||
'index.locked': 1
|
first.addDirector(directors, locked=True)
|
||||||
})
|
|
||||||
first.addWriter(writers, locked=True)
|
edits = {
|
||||||
first.addDirector(directors, locked=True)
|
'title.value': title[:-3],
|
||||||
|
'title.locked': 1,
|
||||||
|
'titleSort.value': titleSort[:-3],
|
||||||
|
'titleSort.locked': 1,
|
||||||
|
'summary.value': summary[:-2],
|
||||||
|
'summary.locked': 1,
|
||||||
|
'originallyAvailableAt.locked': 1,
|
||||||
|
'contentRating.locked': 1
|
||||||
|
}
|
||||||
|
|
||||||
|
if renumber:
|
||||||
|
edits['index.value'] = index
|
||||||
|
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)
|
||||||
|
Loading…
Reference in New Issue
Block a user