diff options
Diffstat (limited to 'youtube_dl/extractor/lifenews.py')
| -rw-r--r-- | youtube_dl/extractor/lifenews.py | 101 | 
1 files changed, 68 insertions, 33 deletions
diff --git a/youtube_dl/extractor/lifenews.py b/youtube_dl/extractor/lifenews.py index f8cbca7b3..a8fd639cc 100644 --- a/youtube_dl/extractor/lifenews.py +++ b/youtube_dl/extractor/lifenews.py @@ -20,18 +20,18 @@ class LifeNewsIE(InfoExtractor):      _VALID_URL = r'http://lifenews\.ru/(?:mobile/)?(?P<section>news|video)/(?P<id>\d+)'      _TESTS = [{ -        'url': 'http://lifenews.ru/news/126342', -        'md5': 'e1b50a5c5fb98a6a544250f2e0db570a', +        # single video embedded via video/source +        'url': 'http://lifenews.ru/news/98736', +        'md5': '77c95eaefaca216e32a76a343ad89d23',          'info_dict': { -            'id': '126342', +            'id': '98736',              'ext': 'mp4', -            'title': 'МВД разыскивает мужчин, оставивших в IKEA сумку с автоматом', -            'description': 'Камеры наблюдения гипермаркета зафиксировали троих мужчин, спрятавших оружейный арсенал в камере хранения.', -            'thumbnail': 're:http://.*\.jpg', -            'upload_date': '20140130', +            'title': 'Мужчина нашел дома архив оборонного завода', +            'description': 'md5:3b06b1b39b5e2bea548e403d99b8bf26', +            'upload_date': '20120805',          }      }, { -        # video in <iframe> +        # single video embedded via iframe          'url': 'http://lifenews.ru/news/152125',          'md5': '77d19a6f0886cd76bdbf44b4d971a273',          'info_dict': { @@ -42,15 +42,33 @@ class LifeNewsIE(InfoExtractor):              'upload_date': '20150402',          }      }, { +        # two videos embedded via iframe          'url': 'http://lifenews.ru/news/153461', -        'md5': '9b6ef8bc0ffa25aebc8bdb40d89ab795',          'info_dict': {              'id': '153461', -            'ext': 'mp4',              'title': 'В Москве спасли потерявшегося медвежонка, который спрятался на дереве',              'description': 'Маленький хищник не смог найти дорогу домой и обрел временное убежище на тополе недалеко от жилого массива, пока его не нашла соседская собака.',              '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',          'only_matching': True, @@ -65,10 +83,14 @@ class LifeNewsIE(InfoExtractor):              'http://lifenews.ru/%s/%s' % (section, video_id),              video_id, 'Downloading page') -        videos = re.findall(r'<video.*?poster="(?P<poster>[^"]+)".*?src="(?P<video>[^"]+)".*?></video>', webpage) -        iframe_link = self._html_search_regex( -            '<iframe[^>]+src=["\']([^"\']+)["\']', webpage, 'iframe link', default=None) -        if not videos and not iframe_link: +        video_urls = re.findall( +            r'<video[^>]+><source[^>]+src=["\'](.+?)["\']', webpage) + +        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)          title = remove_end( @@ -95,31 +117,44 @@ class LifeNewsIE(InfoExtractor):              '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.update({ -                'id': video_id, -                'url': media[1], -                'thumbnail': media[0], -                'title': title if video_number is None else '%s-video%s' % (title, video_number), +                'id': video_id if not index else '%s-video%s' % (video_id, index), +                'url': video_url, +                'title': title if not index else '%s (Видео %s)' % (title, index),              })              return cur_info -        if iframe_link: -            iframe_link = self._proto_relative_url(iframe_link, 'http:') -            cur_info = dict(common_info) -            cur_info.update({ -                '_type': 'url_transparent', -                'id': video_id, -                'title': title, -                'url': iframe_link, -            }) +        def make_video_entry(video_id, video_url, index=None): +            video_url = compat_urlparse.urljoin(url, video_url) +            return make_entry(video_id, video_url, index) + +        def make_iframe_entry(video_id, video_url, index=None): +            video_url = self._proto_relative_url(video_url, 'http:') +            cur_info = make_entry(video_id, video_url, index) +            cur_info['_type'] = 'url_transparent'              return cur_info -        if len(videos) == 1: -            return make_entry(video_id, videos[0]) -        else: -            return [make_entry(video_id, media, video_number + 1) for video_number, media in enumerate(videos)] +        if len(video_urls) == 1 and not iframe_links: +            return make_video_entry(video_id, video_urls[0]) + +        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):  | 
