diff options
| -rw-r--r-- | youtube_dl/extractor/youtube.py | 10 | 
1 files changed, 7 insertions, 3 deletions
| diff --git a/youtube_dl/extractor/youtube.py b/youtube_dl/extractor/youtube.py index ce2212a7c..53dccdf0b 100644 --- a/youtube_dl/extractor/youtube.py +++ b/youtube_dl/extractor/youtube.py @@ -2356,17 +2356,21 @@ class YoutubeIE(YoutubeBaseInfoExtractor):          m_cat_container = self._search_regex(              r'(?s)<h4[^>]*>\s*Category\s*</h4>\s*<ul[^>]*>(.*?)</ul>',              video_webpage, 'categories', default=None) +        category = None          if m_cat_container:              category = self._html_search_regex(                  r'(?s)<a[^<]+>(.*?)</a>', m_cat_container, 'category',                  default=None) -            video_categories = None if category is None else [category] -        else: -            video_categories = None +        if not category: +            category = try_get( +                microformat, lambda x: x['category'], compat_str) +        video_categories = None if category is None else [category]          video_tags = [              unescapeHTML(m.group('content'))              for m in re.finditer(self._meta_regex('og:video:tag'), video_webpage)] +        if not video_tags: +            video_tags = try_get(video_details, lambda x: x['keywords'], list)          def _extract_count(count_name):              return str_to_int(self._search_regex( | 
