本文介绍了从YouTube、SoundCloud和其他平台获取元数据和MRL的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

目前我正在使用LibVLC获取在线视频音乐的元数据和MRL

但仅为了获取此信息就需要大量愚蠢的开销。

...
from vlc import Instance as vlcInstance, MediaList, MediaListPlayer, Event, EventType, State
...
self.player = MediaListPlayer(vlcInstance(options))
...
        self.list = MediaList(self._mrls)
        self.player.set_media_list(self.list)
...
        media = self.player.get_media_player().get_media()
        if media.get_meta(1) is not None and self.trackChangedEventCallback is not None:
            self.trackChangedEventCallback(
                media.get_meta(0),  # Title
                media.get_meta(1),  # Artist
                media.get_meta(6),  # Description
                media.get_meta(10), # URL
                media.get_meta(15)  # Artlink
            )
        print(media.get_mrl()) # MRL
...

当然,有适用于不同平台的包,但我不想用另一个愚蠢的开销替换一个愚蠢的开销。我已经快速查看了VLC的youtube.lua脚本,但我没有找到一个好主意。LibVLC如何执行此解析以获取元数据和MRL?

网络抓取是另一个想法,但在这一点上对我来说似乎不太可靠。

那么,我如何才能在不使用巨大开销的情况下实现与LibVLC-Code相同的功能呢?希望有一个基于urllib的工作解决方案或其他解决方案。

可能的重复项:How can I parse YouTube and SoundCloud?

推荐答案

经过测试,我决定使用youtube_dl,因为它非常好用,并且支持很多平台:http://ytdl-org.github.io/youtube-dl/supportedsites.html

以下是我的示例代码:

#!/usr/bin/env python3
import youtube_dl as ydl

url = "https://www.youtube.com/watch?v=6qEzh3wKVJc"

with ydl.YoutubeDL(
    {
        "forcejson": True,
        "noplaylist": True,
        "format": "bestaudio"
    }
) as parser:
    meta = parser.extract_info(
        url,
        download=False
    )

print(meta['thumbnail'])
print(meta['title'])
print(meta['url'])

这篇关于从YouTube、SoundCloud和其他平台获取元数据和MRL的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

11-02 15:00