diff options
| author | Sergey M. <dstftw@gmail.com> | 2014-02-21 17:19:55 +0700 | 
|---|---|---|
| committer | Sergey M. <dstftw@gmail.com> | 2014-02-21 17:19:55 +0700 | 
| commit | dbb94fb044abae465644bb14daa45b0658ef5cf0 (patch) | |
| tree | 2a5f0b00eff2ab9cceb9d2c9c5155ae829477a12 | |
| parent | eae16eb67b4e0c7deea4a56cae19650aab809662 (diff) | |
[youtube] Fix playlist extraction (Closes #2423, #2424, #2425)
| -rw-r--r-- | youtube_dl/extractor/youtube.py | 30 | 
1 files changed, 16 insertions, 14 deletions
diff --git a/youtube_dl/extractor/youtube.py b/youtube_dl/extractor/youtube.py index 02c5ede74..8e768ea4f 100644 --- a/youtube_dl/extractor/youtube.py +++ b/youtube_dl/extractor/youtube.py @@ -1443,9 +1443,9 @@ class YoutubePlaylistIE(YoutubeBaseInfoExtractor):                       |                          ((?:PL|EC|UU|FL|RD)[0-9A-Za-z-_]{10,})                       )""" -    _TEMPLATE_URL = 'https://www.youtube.com/playlist?list=%s&page=%s' +    _TEMPLATE_URL = 'https://www.youtube.com/playlist?list=%s'      _MORE_PAGES_INDICATOR = r'data-link-type="next"' -    _VIDEO_RE = r'href="/watch\?v=(?P<id>[0-9A-Za-z_-]{11})&[^"]*?index=(?P<index>\d+)' +    _VIDEO_RE = r'href="\s*/watch\?v=(?P<id>[0-9A-Za-z_-]{11})&[^"]*?index=(?P<index>\d+)'      IE_NAME = u'youtube:playlist'      def _real_initialize(self): @@ -1493,29 +1493,31 @@ class YoutubePlaylistIE(YoutubeBaseInfoExtractor):              raise ExtractorError(u'For downloading YouTube.com top lists, use '                  u'the "yttoplist" keyword, for example "youtube-dl \'yttoplist:music:Top Tracks\'"', expected=True) +        url = self._TEMPLATE_URL % playlist_id +        page = self._download_webpage(url, playlist_id) +        more_widget_html = content_html = page +          # Extract the video ids from the playlist pages          ids = []          for page_num in itertools.count(1): -            url = self._TEMPLATE_URL % (playlist_id, page_num) -            page = self._download_webpage(url, playlist_id, u'Downloading page #%s' % page_num) -            matches = re.finditer(self._VIDEO_RE, page) +            matches = re.finditer(self._VIDEO_RE, content_html)              # We remove the duplicates and the link with index 0              # (it's not the first video of the playlist)              new_ids = orderedSet(m.group('id') for m in matches if m.group('index') != '0')              ids.extend(new_ids) -            if re.search(self._MORE_PAGES_INDICATOR, page) is None: +            mobj = re.search(r'data-uix-load-more-href="/?(?P<more>[^"]+)"', more_widget_html) +            if not mobj:                  break -        try: -            playlist_title = self._og_search_title(page) -        except RegexNotFoundError: -            self.report_warning( -                u'Playlist page is missing OpenGraph title, falling back ...', -                playlist_id) -            playlist_title = self._html_search_regex( -                r'<h1 class="pl-header-title">(.*?)</h1>', page, u'title') +            more = self._download_json( +                'https://youtube.com/%s' % mobj.group('more'), playlist_id, 'Downloading page #%s' % page_num) +            content_html = more['content_html'] +            more_widget_html = more['load_more_widget_html'] + +        playlist_title = self._html_search_regex( +                r'<h1 class="pl-header-title">\s*(.*?)\s*</h1>', page, u'title')          url_results = self._ids_to_results(ids)          return self.playlist_result(url_results, playlist_id, playlist_title)  | 
