Working on a playlist importer

This commit is contained in:
Salt 2020-03-13 06:08:28 -05:00
parent 89e28db59b
commit 8d20962afc

View File

@ -22,6 +22,7 @@ import json
import logging import logging
import math import math
import pathlib import pathlib
import re
import types import types
import sys import sys
import youtube_dl import youtube_dl
@ -256,7 +257,7 @@ class BadWitch:
self.argparser.add_argument('-d', '--debug', action='store_true', self.argparser.add_argument('-d', '--debug', action='store_true',
help='Show even more status messages') help='Show even more status messages')
self.argparser.add_argument('action', metavar='action', nargs='?', self.argparser.add_argument('action', metavar='action', nargs='?',
choices=['download', 'edit', 'gui', 'list'], choices=['download', 'edit', 'playlist', 'gui', 'list'],
help='Action to perform on the library') help='Action to perform on the library')
# Set up appdirs # Set up appdirs
self.dirs = AppDirs('badwitch', 'rehashedsalt') self.dirs = AppDirs('badwitch', 'rehashedsalt')
@ -285,6 +286,9 @@ class BadWitch:
elif self.args.action == 'edit': elif self.args.action == 'edit':
self.prompt(lib) self.prompt(lib)
return return
elif self.args.action == 'playlist':
self.playlist(lib)
return
elif self.args.action == 'list': elif self.args.action == 'list':
for album, albumcontent in lib.albums.items(): for album, albumcontent in lib.albums.items():
print(album) print(album)
@ -299,8 +303,71 @@ class BadWitch:
print('Nothing to do') print('Nothing to do')
return return
def playlist(self, lib):
in_playlist = input('YouTube Playlist URL: ')
playlist = {}
metadata = {}
artist = ''
album = ''
# Get our video URLs
with youtube_dl.YoutubeDL({'outtmpl': '%(id)s%(ext)s', 'quiet':True,}) as ydl:
print('Extracting information...')
result = ydl.extract_info(in_playlist, download=False)
if 'entries' in result:
entries = result['entries']
for i, item in enumerate(entries):
playlist[i] = {
'title': entries[i]['title'],
'source': entries[i]['webpage_url']
}
# Song tags like these are per-song, so we have to detect them here
if 'artist' in item:
if artist != '' and artist != entries[i]['artist']:
print('Detected multiple artists')
artist = 'Various Artists'
elif artist != entries[i]['artist']:
print('Detected artist ' + entries[i]['artist'])
artist = entries[i]['artist']
if 'album' in item and album == '':
print('Detected album title ' + entries[i]['album'])
album = entries[i]['album']
if 'release_date' in item and 'release_date' not in metadata and entries[i]['release_date'] is not None:
print('Detected release date ' + entries[i]['release_date'])
metadata['release_date'] = entries[i]['release_date']
# If YouTube's song tags didn't work, just grab metadata from the playlist
if album == '':
album = result['title']
if artist == '':
artist = result['uploader']
for field in ['genre', 'publisher', 'release_date']:
if field in metadata:
continue
in_value = input('Metadata: ' + field + ' = ')
if in_value is not '': metadata[field] = in_value
# Remove artist prefixes because that happens a lot
artistregex = re.compile(r'^' + re.escape(artist) + r'[ ]*[-:;~]*[ ]*', re.IGNORECASE)
for song, songcontent in playlist.items():
songcontent['title'] = artistregex.sub('', songcontent['title'])
# Build up an album
playlistalbum = {}
playlistalbum['meta'] = metadata
for song, songcontent in playlist.items():
playlistalbum[songcontent['title']] = {
'track': song,
'artist': artist,
'source': songcontent['source']
}
lib.albums[album] = playlistalbum
lib.validate()
lib.save()
print('Successfully added "' + album + '" by ' + artist)
for song, songcontent in lib.albums[album].items():
if song == 'meta':
continue
print(str(songcontent['track']) + ': ' + song + ' (' + songcontent['source'] + ')')
def prompt(self, lib): def prompt(self, lib):
print('Bad Witch interactive $ibrary editor') print('Bad Witch interactive library editor')
print('^C to abort, ^D to finish changes') print('^C to abort, ^D to finish changes')
print('Loaded library ' + lib.file) print('Loaded library ' + lib.file)
try: try: