Working on a playlist importer
This commit is contained in:
parent
89e28db59b
commit
8d20962afc
71
badwitch.py
71
badwitch.py
@ -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:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user