python - 如何在 youtube-dl 和 discord.py 中使用关键词而不是 url?
问题描述
我正在编写一个通用机器人,基本上我想输入命令,然后输入歌曲名称示例:?play song-name
它将搜索 youtube,并且弹出的第一个视频将下载它的音频
我让机器人与普通链接一起工作,但如果我必须获得链接来播放音乐,它就达不到目的
client = discord.Client()
@client.event
async def on_message(message):
ydl_opts = {
'format': 'beataudio/best',
'postprocessors': [{
'key': 'FFmpegExtractAudio',
'preferredcodec': 'mp3',
'preferredquality': '192'
}]
}
with youtube_dl.YoutubeDL(ydl_opts) as ydl:
print("Downloading audio now\n")
url: str = message.content.replace('?play ', '')
print(url)
ydl.download([url])
我以前没有使用过 youtube-dl,所以我不知道它是如何工作的。
解决方案
获得不和谐搜索查询后,您可以使用:
import youtube_dl # youtube-dl-2020.3.1
import traceback, os, json
from youtube_search import YoutubeSearch # pip install youtube_search
"""
sources :
https://github.com/ytdl-org/youtube-dl/blob/master/README.md#embedding-youtube-dl
https://stackoverflow.com/questions/23727943/how-to-get-information-from-youtube-dl-in-python/31184514#31184514
https://stackoverflow.com/a/43143553/797495
"""
search = 'carlos paiao playback'
ydl_opts = {
'format': 'beataudio/best',
'postprocessors': [{
'key': 'FFmpegExtractAudio',
'preferredcodec': 'mp3',
'preferredquality': '192'
}]
}
yt = YoutubeSearch(search, max_results=1).to_json()
try:
yt_id = str(json.loads(yt)['videos'][0]['id'])
yt_url = 'https://www.youtube.com/watch?v='+yt_id
with youtube_dl.YoutubeDL(ydl_opts) as ydl:
ydl.download([yt_url])
info = ydl.extract_info(yt_url)
songname = info.get('title', None) + "-" + yt_id + ".mp3"
if os.path.isfile(songname):
print("Song Downloaded: " + songname)
else:
print("Error: " + songname)
except:
pass
print(traceback.print_exc())
print("no results")
推荐阅读
- go - 堆栈跟踪中显示的 goroutine 编号是否在 golang 中重用或递增?
- .net - 从 PublicAPI 获取 WebApi 中的 User.Identity
- android - 无法在 MAC OS 上退出 Android Studio
- caching - 为什么以下两个代码会产生不同的结果?
- sass - 包装 SCSS 选择器快捷方式
- mysql - Laravel HasManyThrough,访问主要/次要用户推荐
- c# - 我想从多维数组中获取“索引数组”
- bootstrap-4 - 阻止 Bootstrap 卡以 sm 和 xs 宽度堆叠
- log4j - Flink 鱼标记
- python - R tbats 模型季节性客户标志无结果