aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSergey M․ <dstftw@gmail.com>2017-04-08 20:08:31 +0700
committerSergey M․ <dstftw@gmail.com>2017-04-08 20:08:31 +0700
commit90e3f18fc1cff2c12361cbbd85303774bf7d59f7 (patch)
tree54a76c4b44738528e9cabc0b10c0f90e80ccb6ee
parent5f3e0b69efa8ae80f536fb54ace4bb4d9c667d2e (diff)
[thesun] Extract playlists (closes #11298, closes #12674)
-rw-r--r--youtube_dl/extractor/thesun.py29
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))