mirror of https://github.com/yt-dlp/yt-dlp
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
61 lines
2.0 KiB
Python
61 lines
2.0 KiB
Python
# coding: utf-8
|
|
import datetime
|
|
import json
|
|
import re
|
|
|
|
from .common import InfoExtractor
|
|
from ..utils import (
|
|
remove_start,
|
|
)
|
|
|
|
|
|
class RadioFranceIE(InfoExtractor):
|
|
_VALID_URL = r'^https?://maison\.radiofrance\.fr/radiovisions/(?P<id>[^?#]+)'
|
|
IE_NAME = u'radiofrance'
|
|
|
|
_TEST = {
|
|
u'url': u'http://maison.radiofrance.fr/radiovisions/one-one',
|
|
u'file': u'one-one.mp4',
|
|
u'md5': u'todo',
|
|
u'info_dict': {
|
|
u"title": u"One to one",
|
|
u"description": u"Plutôt que d'imaginer la radio de demain comme technologie ou comme création de contenu, je veux montrer que quelles que soient ses évolutions, j'ai l'intime conviction que la radio continuera d'être un grand média de proximité pour les auditeurs.",
|
|
u"uploader": u"ferdi",
|
|
},
|
|
}
|
|
|
|
def _real_extract(self, url):
|
|
m = re.match(self._VALID_URL, url)
|
|
video_id = m.group('id')
|
|
|
|
webpage = self._download_webpage(url, video_id)
|
|
title = self._html_search_regex(r'<h1>(.*?)</h1>', webpage, u'title')
|
|
description = self._html_search_regex(
|
|
r'<div class="bloc_page_wrapper"><div class="text">(.*?)</div>',
|
|
webpage, u'description', fatal=False)
|
|
uploader = self._html_search_regex(
|
|
r'<div class="credit"> © (.*?)</div>',
|
|
webpage, u'uploader', fatal=False)
|
|
|
|
formats_str = self._html_search_regex(
|
|
r'class="jp-jplayer[^"]*" data-source="([^"]+)">',
|
|
webpage, u'audio URLs')
|
|
formats = [
|
|
{
|
|
'format_id': m[0],
|
|
'url': m[1],
|
|
'vcodec': 'none',
|
|
}
|
|
for m in
|
|
re.findall(r"([a-z0-9]+)\s*:\s*'([^']+)'", formats_str)
|
|
]
|
|
# No sorting, we don't know any more about these formats
|
|
|
|
return {
|
|
'id': video_id,
|
|
'title': title,
|
|
'formats': formats,
|
|
'description': description,
|
|
'uploader': uploader,
|
|
}
|