1
0
Fork 0
mirror of https://github.com/ytdl-org/youtube-dl.git synced 2024-11-25 19:52:11 +00:00

[lifenews] Fix extraction and improve (Closes #2482, closes #8714)

This commit is contained in:
Sergey M․ 2016-03-01 22:59:11 +06:00
parent 9fb556eef0
commit e7998f59aa

View file

@ -20,18 +20,18 @@ class LifeNewsIE(InfoExtractor):
_VALID_URL = r'http://lifenews\.ru/(?:mobile/)?(?P<section>news|video)/(?P<id>\d+)' _VALID_URL = r'http://lifenews\.ru/(?:mobile/)?(?P<section>news|video)/(?P<id>\d+)'
_TESTS = [{ _TESTS = [{
'url': 'http://lifenews.ru/news/126342', # single video embedded via video/source
'md5': 'e1b50a5c5fb98a6a544250f2e0db570a', 'url': 'http://lifenews.ru/news/98736',
'md5': '77c95eaefaca216e32a76a343ad89d23',
'info_dict': { 'info_dict': {
'id': '126342', 'id': '98736',
'ext': 'mp4', 'ext': 'mp4',
'title': 'МВД разыскивает мужчин, оставивших в IKEA сумку с автоматом', 'title': 'Мужчина нашел дома архив оборонного завода',
'description': 'Камеры наблюдения гипермаркета зафиксировали троих мужчин, спрятавших оружейный арсенал в камере хранения.', 'description': 'md5:3b06b1b39b5e2bea548e403d99b8bf26',
'thumbnail': 're:http://.*\.jpg', 'upload_date': '20120805',
'upload_date': '20140130',
} }
}, { }, {
# video in <iframe> # single video embedded via iframe
'url': 'http://lifenews.ru/news/152125', 'url': 'http://lifenews.ru/news/152125',
'md5': '77d19a6f0886cd76bdbf44b4d971a273', 'md5': '77d19a6f0886cd76bdbf44b4d971a273',
'info_dict': { 'info_dict': {
@ -42,15 +42,33 @@ class LifeNewsIE(InfoExtractor):
'upload_date': '20150402', 'upload_date': '20150402',
} }
}, { }, {
# two videos embedded via iframe
'url': 'http://lifenews.ru/news/153461', 'url': 'http://lifenews.ru/news/153461',
'md5': '9b6ef8bc0ffa25aebc8bdb40d89ab795',
'info_dict': { 'info_dict': {
'id': '153461', 'id': '153461',
'ext': 'mp4',
'title': 'В Москве спасли потерявшегося медвежонка, который спрятался на дереве', 'title': 'В Москве спасли потерявшегося медвежонка, который спрятался на дереве',
'description': 'Маленький хищник не смог найти дорогу домой и обрел временное убежище на тополе недалеко от жилого массива, пока его не нашла соседская собака.', 'description': 'Маленький хищник не смог найти дорогу домой и обрел временное убежище на тополе недалеко от жилого массива, пока его не нашла соседская собака.',
'upload_date': '20150505', 'upload_date': '20150505',
} },
'playlist': [{
'md5': '9b6ef8bc0ffa25aebc8bdb40d89ab795',
'info_dict': {
'id': '153461-video1',
'ext': 'mp4',
'title': 'В Москве спасли потерявшегося медвежонка, который спрятался на дереве (Видео 1)',
'description': 'Маленький хищник не смог найти дорогу домой и обрел временное убежище на тополе недалеко от жилого массива, пока его не нашла соседская собака.',
'upload_date': '20150505',
},
}, {
'md5': 'ebb3bf3b1ce40e878d0d628e93eb0322',
'info_dict': {
'id': '153461-video2',
'ext': 'mp4',
'title': 'В Москве спасли потерявшегося медвежонка, который спрятался на дереве (Видео 2)',
'description': 'Маленький хищник не смог найти дорогу домой и обрел временное убежище на тополе недалеко от жилого массива, пока его не нашла соседская собака.',
'upload_date': '20150505',
},
}],
}, { }, {
'url': 'http://lifenews.ru/video/13035', 'url': 'http://lifenews.ru/video/13035',
'only_matching': True, 'only_matching': True,
@ -65,10 +83,14 @@ class LifeNewsIE(InfoExtractor):
'http://lifenews.ru/%s/%s' % (section, video_id), 'http://lifenews.ru/%s/%s' % (section, video_id),
video_id, 'Downloading page') video_id, 'Downloading page')
videos = re.findall(r'<video.*?poster="(?P<poster>[^"]+)".*?src="(?P<video>[^"]+)".*?></video>', webpage) video_urls = re.findall(
iframe_link = self._html_search_regex( r'<video[^>]+><source[^>]+src=["\'](.+?)["\']', webpage)
'<iframe[^>]+src=["\']([^"\']+)["\']', webpage, 'iframe link', default=None)
if not videos and not iframe_link: iframe_links = re.findall(
r'<iframe[^>]+src=["\']((?:https?:)?//embed\.life\.ru/embed/.+?)["\']',
webpage)
if not video_urls and not iframe_links:
raise ExtractorError('No media links available for %s' % video_id) raise ExtractorError('No media links available for %s' % video_id)
title = remove_end( title = remove_end(
@ -95,31 +117,44 @@ class LifeNewsIE(InfoExtractor):
'upload_date': upload_date, 'upload_date': upload_date,
} }
def make_entry(video_id, media, video_number=None): def make_entry(video_id, video_url, index=None):
cur_info = dict(common_info) cur_info = dict(common_info)
cur_info.update({ cur_info.update({
'id': video_id, 'id': video_id if not index else '%s-video%s' % (video_id, index),
'url': media[1], 'url': video_url,
'thumbnail': media[0], 'title': title if not index else '%s (Видео %s)' % (title, index),
'title': title if video_number is None else '%s-video%s' % (title, video_number),
}) })
return cur_info return cur_info
if iframe_link: def make_video_entry(video_id, video_url, index=None):
iframe_link = self._proto_relative_url(iframe_link, 'http:') video_url = compat_urlparse.urljoin(url, video_url)
cur_info = dict(common_info) return make_entry(video_id, video_url, index)
cur_info.update({
'_type': 'url_transparent', def make_iframe_entry(video_id, video_url, index=None):
'id': video_id, video_url = self._proto_relative_url(video_url, 'http:')
'title': title, cur_info = make_entry(video_id, video_url, index)
'url': iframe_link, cur_info['_type'] = 'url_transparent'
})
return cur_info return cur_info
if len(videos) == 1: if len(video_urls) == 1 and not iframe_links:
return make_entry(video_id, videos[0]) return make_video_entry(video_id, video_urls[0])
else:
return [make_entry(video_id, media, video_number + 1) for video_number, media in enumerate(videos)] if len(iframe_links) == 1 and not video_urls:
return make_iframe_entry(video_id, iframe_links[0])
entries = []
if video_urls:
for num, video_url in enumerate(video_urls, 1):
entries.append(make_video_entry(video_id, video_url, num))
if iframe_links:
for num, iframe_link in enumerate(iframe_links, len(video_urls) + 1):
entries.append(make_iframe_entry(video_id, iframe_link, num))
playlist = common_info.copy()
playlist.update(self.playlist_result(entries, video_id, title, description))
return playlist
class LifeEmbedIE(InfoExtractor): class LifeEmbedIE(InfoExtractor):