mirror of
				https://gitlab.com/ytdl-org/youtube-dl.git
				synced 2025-11-04 03:27:06 -05:00 
			
		
		
		
	@@ -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)
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user