#python #youtube-dl
Вопрос:
У меня есть бот на python, который может воспроизводить музыку в голосовых каналах. Я использовал класс YTDLSource отсюда и отредактировал этот класс для поддержки списков воспроизведения. Вот мой исходный код YTDLSource:
youtube_dl.utils.bug_reports_message = lambda: ''
ytdl_format_options = {
'format': 'bestaudio/best',
'outtmpl': '%(extractor)s-%(id)s-%(title)s.%(ext)s',
'restrictfilenames': True,
'noplaylist': False,
'nocheckcertificate': True,
'ignoreerrors': False,
'logtostderr': False,
'quiet': True,
'no_warnings': True,
'default_search': 'auto',
'source_address': '0.0.0.0'
}
ffmpeg_options = {
'options': '-vn',
"before_options": "-reconnect 1 -reconnect_streamed 1 -reconnect_delay_max 5"
}
ytdl = youtube_dl.YoutubeDL(ytdl_format_options)
class YTDLSource(discord.PCMVolumeTransformer):
def __init__(self, data, *, volume=0.5):
super().__init__(discord.FFmpegPCMAudio(data['url'], **ffmpeg_options), volume)
self.data = data
self.title = data.get('title')
self.url = data.get('webpage_url')
@classmethod
async def get(cls, url, *, volume=0.5):
loop = asyncio.get_event_loop()
data = await loop.run_in_executor(None, lambda: ytdl.extract_info(url, download=False))
if 'entries' in data:
return [cls(entry, volume=volume) for entry in data['entries']]
else:
return cls(data, volume=volume)
Код работает, но слишком медленно. Я проверил, сколько времени требуется youtube_dl
для извлечения информации из списка воспроизведения, следующим образом:
time1 = time.time()
data = await loop.run_in_executor(None, lambda: ytdl.extract_info(url, download=False))
print(f"Extracted info in {time.time() - time1} seconds")
И я получил Extracted info in 12.71654725074768 seconds
. Я протестировал это с помощью плейлиста с 14 треками из SoundCloud.
Является ли такое поведение нормальным youtube_dl
или я делаю что-то не так?
Ответ №1:
youtube_dl
следует загружать и анализировать данные из каждой песни в плейлисте, так что неудивительно, что это занимает так много времени.
Лучше загрузить песню, которая должна играть следующей в очереди, так это будет намного быстрее и проблема будет решена.