Added quality choice based on format

This commit is contained in:
asuyou
2021-10-28 11:19:17 +01:00
parent b3a589f1a9
commit d051814259
5 changed files with 145 additions and 42 deletions

85
app/dl_formats.py Normal file
View File

@@ -0,0 +1,85 @@
def get_format(format: str, quality: str) -> str:
"""
Returns format for download
Args:
format (str): format selected
quality (str): quality selected
Raises:
Exception: unknown quality, unknown format
Returns:
dl_format: Formatted download string
"""
audio_fmt = ""
video_fmt = ""
final_fmt = ""
if format.startswith("custom: "):
final_fmt = format[7:]
elif format == "any":
final_fmt = "bv*+ba/b"
elif format == "mp3":
audio_fmt = _get_audio_fmt(quality)
elif format == "mp4":
audio_fmt = "ba/b"
video_fmt = _get_video_fmt(quality)
else:
raise Exception(f"Unknown format {format}")
if not final_fmt:
final_fmt = video_fmt + audio_fmt
return final_fmt
def get_opts(format: str, quality: str, ytdl_opts: dict) -> dict:
"""
Returns extra download options
Mostly postprocessing options
Args:
format (str): format selected
quality (str): quality of format selected (needed for some formats)
ytdl_opts (dict): current options selected
Returns:
ytdl_opts: Extra options
"""
if "postprocessors" not in ytdl_opts:
ytdl_opts["postprocessors"] = []
if format == "mp3":
extra_args = {}
if quality != "best":
extra_args = {"preferredquality": quality}
ytdl_opts["postprocessors"].append(
{"key": "FFmpegExtractAudio", "preferredcodec": "mp3", **extra_args},
)
elif format == "mp4":
ytdl_opts["merge_output_format"] = "mp4"
return ytdl_opts
def _get_audio_fmt(quality: str) -> str:
if quality == "best" or quality in ("128", "192", "320"):
audio_fmt = "ba/b"
# Audio quality needs to be set post-download, set in opts
else:
raise Exception(f"Unknown quality {quality}")
return audio_fmt
def _get_video_fmt(quality: str) -> str:
if quality == "best":
video_fmt = "bv*+"
elif quality in ("1440", "1080", "720", "480"):
video_fmt = f"bv[height<={quality}]+"
else:
raise Exception(f"Unknown quality {quality}")
return video_fmt

View File

@@ -4,6 +4,7 @@ from collections import OrderedDict
import asyncio
import multiprocessing
import logging
from dl_formats import get_format, get_opts
log = logging.getLogger('ytdl')
@@ -36,29 +37,8 @@ class Download:
def __init__(self, download_dir, output_template, quality, format, ytdl_opts, info):
self.download_dir = download_dir
self.output_template = output_template
vfmt, afmt = '', ''
if format == 'mp4':
vfmt, afmt = '[ext=mp4]', '[ext=m4a]'
elif format == 'mp3':
afmt = '/best'
ytdl_opts["writethumbnail"] = True
ytdl_opts["postprocessors"] = [
{"key": "FFmpegExtractAudio", "preferredcodec": "mp3"},
{"key": "EmbedThumbnail"},
]
if quality == 'best':
self.format = f'bestvideo{vfmt}+bestaudio{afmt}/best{vfmt}'
elif quality in ('1440p', '1080p', '720p', '480p'):
res = quality[:-1]
self.format = f'bestvideo[height<={res}]{vfmt}+bestaudio{afmt}/best[height<={res}]{vfmt}'
elif quality == 'audio':
self.format = f'bestaudio{afmt}'
elif quality.startswith('custom:'):
self.format = quality[7:]
else:
raise Exception(f'unknown quality {quality}')
self.ytdl_opts = ytdl_opts
self.format = get_format(format, quality)
self.ytdl_opts = get_opts(format, quality, ytdl_opts)
self.info = info
self.canceled = False
self.tmpfilename = None