Nic*_*k D 9 python youtube audio url stream
我一直在尝试创建一种直接从 python 代码流式传输 youtube url(最好只有音频,尽管这并不重要)的方法。我尝试了很多东西,但似乎没有一个真正有效。到目前为止,我能够使用 youtube 数据 api 搜索视频或播放列表,抓取第一个视频或播放列表并将其传递给 pafy 以获得不同的流媒体网址。有谁知道一种无需先下载视频即可通过 python 播放 youtube 音频/视频的方法?我认为可以使用 mplayer 或 vlc 等 cmd 行工具使用子进程为 cmd 行弹出一个 cmd 并传入 url,但我被卡住了。需要任何帮助。请!这是我的以下代码:
import argparse
import pafy
from googleapiclient.discovery import build
from googleapiclient.errors import HttpError
DEVELOPER_KEY = 'DEVELOPER KEY'
YOUTUBE_API_SERVICE_NAME = 'youtube'
YOUTUBE_API_VERSION = 'v3'
def pafy_video(video_id):
url = 'https://www.youtube.com/watch?v={0}'.format(video_id)
vid = pafy.new(url)
def pafy_playlist(playlist_id)
url = "https://www.youtube.com/playlist?list={0}".format(playlist_id)
playlist = pafy.get_playlist(url)
def youtube_search(options):
youtube = build(YOUTUBE_API_SERVICE_NAME, YOUTUBE_API_VERSION, developerKey=DEVELOPER_KEY)
search_response = youtube.search().list(
q='Hello world',
part='id,snippet',
maxResults=options.max_results
).execute()
videos = []
playlists = []
channels = []
for search_result in search_response.get('items', []):
if search_result['id']['kind'] == 'youtube#video':
videos.append('%s' % (search_result['id']['videoId']))
elif search_result['id']['kind'] == 'youtube#channel':
channels.append('%s' % (search_result['id']['channelId']))
elif search_result['id']['kind'] == 'youtube#playlist':
playlists.append('%s' % (search_result['id']['playlistId']))
if videos:
print('Videos:{0}'.format(videos))
pafy_video(videos[0])
elif playlists:
print('Playlists:{0}'.format(playlists))
pafy_video(playlists[0])
#https://www.youtube.com/watch?v=rOU4YiuaxAM
#url = 'https://www.youtube.com/watch?v={0}'.format(videos[0])
#print(url)
if __name__ == '__main__':
parser = argparse.ArgumentParser()
parser.add_argument('--q', help='Search term', default='Google')
parser.add_argument('--max-results', help='Max results', default=3)
args = parser.parse_args()
youtube_search(args)
Run Code Online (Sandbox Code Playgroud)
网址; 我想直接从 python 代码流式传输 youtube 视频(使用 url 或 id),而无需先下载视频
谢谢!
pafy根据其文档,不要直接列出播放媒体(至少我没有找到)。
但是我们可以使用它来获取正确的url,然后使用播放器等vlc直接播放,无需下载。
首先,我们从youtube使用中获得正确/最佳的 URLpafy
import pafy
import vlc
url = "https://www.youtube.com/watch?v=bMt47wvK6u0"
video = pafy.new(url)
best = video.getbest()
playurl = best.url
Run Code Online (Sandbox Code Playgroud)
这里playurl是最好玩的网址。然后我们使用VLC来播放它。
Instance = vlc.Instance()
player = Instance.media_player_new()
Media = Instance.media_new(playurl)
Media.get_mrl()
player.set_media(Media)
player.play()
Run Code Online (Sandbox Code Playgroud)
这将打开一个没有控件(播放/暂停/停止等)的窗口。您可以在repr窗口或 python 提示符下运行这些命令(取决于您使用它的方式)
您需要使用 vlc 命令相应地构建一个,例如
>>> player.pause() #-- to pause video
>>> player.play() #-- resume paused video. On older versions,
# this function was called resume
>>> player.stop() #-- to stop/end video
Run Code Online (Sandbox Code Playgroud)
实现此目的的最佳方法是将mpv与youtube-dl(一种带有命令行控制台的轻量级媒体播放器,它允许您通过将 url 复制和粘贴到 mpv 控制台来流式传输任何类型的视频/音频编解码器(适用于cmd 和终端)。用法:path\to\mpv https://your/video/audioURL.com/
首先导入这些模块 - 通过安装 pip install bs4 requests
import re, requests, subprocess, urllib.parse, urllib.request
from bs4 import BeautifulSoup
Run Code Online (Sandbox Code Playgroud)
然后创建一个变量来存储您选择的音乐标题
music_name = "Linkin Park Numb"
query_string = urllib.parse.urlencode({"search_query": music_name})
Run Code Online (Sandbox Code Playgroud)
这里的目标是使用此搜索查询来提取第一个视频结果的输出标题和链接。然后,我们可以"https://www.youtube.com/results?search_query="使用标识符对 youtube 网址进行结束编码urllib(例如,"https://www.youtube.com/results?search_query=linkin+park+numb")
formatUrl = urllib.request.urlopen("https://www.youtube.com/results?" + query_string)
Run Code Online (Sandbox Code Playgroud)
此处re.findall(r"watch\?v=(\S{11})"查看来自我们查询的所有视频结果的 11 个字符标识符
search_results = re.findall(r"watch\?v=(\S{11})", formatUrl.read().decode())
Run Code Online (Sandbox Code Playgroud)
解码内容后,我们可以通过将主 youtube url 与 11 个字符标识符连接来提取完整的 url
clip = requests.get("https://www.youtube.com/watch?v=" + "{}".format(search_results[0]))
clip2 = "https://www.youtube.com/watch?v=" + "{}".format(search_results[0])
print(clip2)
Run Code Online (Sandbox Code Playgroud)
https://www.youtube.com/watch?v=kXYiU_JCYtU为了进一步检查内容,我们可以使用beautifulsoup来抓取视频的确切标题
inspect = BeautifulSoup(clip.content, "html.parser")
yt_title = inspect.find_all("meta", property="og:title")
for concatMusic1 in yt_title:
pass
print(concatMusic1['content'])
Run Code Online (Sandbox Code Playgroud)
Numb (Official Video) - Linkin Park最后,为了播放我们的音乐,我们将其输入到命令行
subprocess.Popen(
"start /b " + "path\\to\\mpv.exe" + clip2 + " --no-video --loop=inf --input-ipc-server=\\\\.\\pipe\\mpv-pipe > output.txt",
shell=True)
Run Code Online (Sandbox Code Playgroud)
================================================== ==================
import re, requests, subprocess, urllib.parse, urllib.request
from bs4 import BeautifulSoup
music_name = "Linkin Park Numb"
query_string = urllib.parse.urlencode({"search_query": music_name})
formatUrl = urllib.request.urlopen("https://www.youtube.com/results?" + query_string)
search_results = re.findall(r"watch\?v=(\S{11})", formatUrl.read().decode())
clip = requests.get("https://www.youtube.com/watch?v=" + "{}".format(search_results[0]))
clip2 = "https://www.youtube.com/watch?v=" + "{}".format(search_results[0])
inspect = BeautifulSoup(clip.content, "html.parser")
yt_title = inspect.find_all("meta", property="og:title")
for concatMusic1 in yt_title:
pass
print(concatMusic1['content'])
subprocess.Popen(
"start /b " + "path\\to\\mpv.exe " + clip2 + " --no-video --loop=inf --input-ipc-server=\\\\.\\pipe\\mpv-pipe > output.txt",
shell=True)
# Alternatively, you can do this for simplicity sake:
# subprocess.Popen("start /b " + "path\\to\\mpv.exe " + clip2 + "--no-video", shell=True)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
42767 次 |
| 最近记录: |