diff options
| author | Sergey M․ <dstftw@gmail.com> | 2016-11-02 01:35:53 +0700 | 
|---|---|---|
| committer | Sergey M․ <dstftw@gmail.com> | 2016-11-02 01:35:53 +0700 | 
| commit | f449c061d04b37f70dafa8c01a2e1fb7a47a9a5f (patch) | |
| tree | 86f7e8ea9352b1771106e1862bd2b0733cde8fd6 | |
| parent | 9c82bba05d5495d29be2ee20fc9cb690b37fcdce (diff) | |
[nicknight] Improve extraction (closes #10769)
| -rw-r--r-- | youtube_dl/extractor/extractors.py | 2 | ||||
| -rw-r--r-- | youtube_dl/extractor/nick.py | 28 | 
2 files changed, 14 insertions, 16 deletions
diff --git a/youtube_dl/extractor/extractors.py b/youtube_dl/extractor/extractors.py index 913ffe29a..f30ac5aaf 100644 --- a/youtube_dl/extractor/extractors.py +++ b/youtube_dl/extractor/extractors.py @@ -596,7 +596,7 @@ from .nhl import (  from .nick import (      NickIE,      NickDeIE, -    NickNightAtIE, +    NickNightIE,  )  from .niconico import NiconicoIE, NiconicoPlaylistIE  from .ninecninemedia import ( diff --git a/youtube_dl/extractor/nick.py b/youtube_dl/extractor/nick.py index 36364bee9..7672845bf 100644 --- a/youtube_dl/extractor/nick.py +++ b/youtube_dl/extractor/nick.py @@ -86,6 +86,11 @@ class NickDeIE(MTVServicesInfoExtractor):          'only_matching': True,      }] +    def _extract_mrss_url(self, webpage, host): +        return update_url_query(self._search_regex( +            r'data-mrss=(["\'])(?P<url>http.+?)\1', webpage, 'mrss url', group='url'), +            {'siteKey': host}) +      def _real_extract(self, url):          mobj = re.match(self._VALID_URL, url)          video_id = mobj.group('id') @@ -93,16 +98,14 @@ class NickDeIE(MTVServicesInfoExtractor):          webpage = self._download_webpage(url, video_id) -        mrss_url = update_url_query(self._search_regex( -            r'data-mrss=(["\'])(?P<url>http.+?)\1', webpage, 'mrss url', group='url'), -            {'siteKey': host}) +        mrss_url = self._extract_mrss_url(webpage, host)          return self._get_videos_info_from_url(mrss_url, video_id) -class NickNightAtIE(MTVServicesInfoExtractor): -    IE_NAME = 'nicknight.de' -    _VALID_URL = r'https?://(?:www\.)nicknight\.(?:de|at|tv)/(?:playlist|shows)/(?:[^/]+/)*(?P<id>[^/?#&]+)' +class NickNightIE(NickDeIE): +    IE_NAME = 'nicknight' +    _VALID_URL = r'https?://(?:www\.)(?P<host>nicknight\.(?:de|at|tv))/(?:playlist|shows)/(?:[^/]+/)*(?P<id>[^/?#&]+)'      _TESTS = [{          'url': 'http://www.nicknight.at/shows/977-awkward/videos/85987-nimmer-beste-freunde',          'only_matching': True, @@ -114,12 +117,7 @@ class NickNightAtIE(MTVServicesInfoExtractor):          'only_matching': True,      }] -    def _real_extract(self, url): -        video_id = self._match_id(url) - -        webpage = self._download_webpage(url, video_id) - -        mrss_url = self._search_regex( -            r'mrss: (["\'])(?P<url>http.+?)\1', webpage, 'mrss url', group='url') - -        return self._get_videos_info_from_url(mrss_url, video_id) +    def _extract_mrss_url(self, webpage, *args): +        return self._search_regex( +            r'mrss\s*:\s*(["\'])(?P<url>http.+?)\1', webpage, +            'mrss url', group='url')  | 
