diff options
author | Sergey M․ <dstftw@gmail.com> | 2017-04-08 20:08:31 +0700 |
---|---|---|
committer | Sergey M․ <dstftw@gmail.com> | 2017-04-08 20:08:31 +0700 |
commit | 90e3f18fc1cff2c12361cbbd85303774bf7d59f7 (patch) | |
tree | 54a76c4b44738528e9cabc0b10c0f90e80ccb6ee | |
parent | 5f3e0b69efa8ae80f536fb54ace4bb4d9c667d2e (diff) |
[thesun] Extract playlists (closes #11298, closes #12674)
-rw-r--r-- | youtube_dl/extractor/thesun.py | 29 |
1 files changed, 17 insertions, 12 deletions
diff --git a/youtube_dl/extractor/thesun.py b/youtube_dl/extractor/thesun.py index 7f96bf8c9..22d003776 100644 --- a/youtube_dl/extractor/thesun.py +++ b/youtube_dl/extractor/thesun.py @@ -1,27 +1,32 @@ from __future__ import unicode_literals +import re + from .common import InfoExtractor from .ooyala import OoyalaIE class TheSunIE(InfoExtractor): - _VALID_URL = r'https://(?:www\.)?thesun\.co\.uk/\w+/(?P<id>\d+)/[\w-]' + _VALID_URL = r'https://(?:www\.)?thesun\.co\.uk/[^/]+/(?P<id>\d+)' _TEST = { 'url': 'https://www.thesun.co.uk/tvandshowbiz/2261604/orlando-bloom-and-katy-perry-post-adorable-instagram-video-together-celebrating-thanksgiving-after-split-rumours/', - 'md5': '5667123b24f25f43f4c4f381ef34c5c2', 'info_dict': { - 'id': 'h4OXN0NzE6rv6ObkEifKcNA-gYUw4xFf', - 'ext': 'mp4', - 'title': 'Katy Perry and Orlando Bloom shut down split rumours with cute Thanksgiving video', - 'description': 'Still going strong', - 'duration': 31.28, - } + 'id': '2261604', + 'title': 'md5:cba22f48bad9218b64d5bbe0e16afddf', + }, + 'playlist_count': 2, } def _real_extract(self, url): - video_id = self._match_id(url) + article_id = self._match_id(url) + + webpage = self._download_webpage(url, article_id) - webpage = self._download_webpage(url, video_id) - ooyala_id = self._search_regex(r'id\s*=\s*"thesun-ooyala-player-([^"]+)"', webpage, 'ooyala id') + entries = [] + for ooyala_id in re.findall( + r'<[^>]+\b(?:id\s*=\s*"thesun-ooyala-player-|data-content-id\s*=\s*")([^"]+)', + webpage): + entries.append(OoyalaIE._build_url_result(ooyala_id)) - return OoyalaIE._build_url_result(ooyala_id) + return self.playlist_result( + entries, article_id, self._og_search_title(webpage, fatal=False)) |