diff options
Diffstat (limited to 'youtube_dl/extractor')
| -rw-r--r-- | youtube_dl/extractor/youtube.py | 22 | 
1 files changed, 16 insertions, 6 deletions
| diff --git a/youtube_dl/extractor/youtube.py b/youtube_dl/extractor/youtube.py index 07c0f6ef9..0869c9fd4 100644 --- a/youtube_dl/extractor/youtube.py +++ b/youtube_dl/extractor/youtube.py @@ -1291,12 +1291,22 @@ class YoutubePlaylistIE(YoutubeBaseInfoExtractor):          page = self._download_webpage(url, playlist_id)          more_widget_html = content_html = page -        # Check if the playlist exists or is private -        if re.search(r'<div class="yt-alert-message">[^<]*?(The|This) playlist (does not exist|is private)[^<]*?</div>', page) is not None: -            raise ExtractorError( -                'The playlist doesn\'t exist or is private, use --username or ' -                '--netrc to access it.', -                expected=True) +        for match in re.findall(r'<div class="yt-alert-message">([^<]+)</div>', page): +            match = match.strip() +            # Check if the playlist exists or is private +            if re.match(r'[^<]*(The|This) playlist (does not exist|is private)[^<]*', match): +                raise ExtractorError( +                    'The playlist doesn\'t exist or is private, use --username or ' +                    '--netrc to access it.', +                    expected=True) +            elif re.match(r'[^<]*Invalid parameters[^<]*', match): +                raise ExtractorError( +                    'Invalid parameters. Maybe URL is incorrect.', +                    expected=True) +            elif re.match(r'[^<]*Choose your language[^<]*', match): +                continue +            else: +                self.report_warning('Youtube gives an alert message: ' + match)          # Extract the video ids from the playlist pages          ids = [] | 
