[youtube] Fix uploader for collaborative playlists (#3332)
Authored by: coletdjnz
This commit is contained in:
parent
870efdee28
commit
61d3665d9d
2 changed files with 27 additions and 6 deletions
|
@ -23,6 +23,7 @@ from ..compat import (
|
||||||
compat_getpass,
|
compat_getpass,
|
||||||
compat_http_client,
|
compat_http_client,
|
||||||
compat_os_name,
|
compat_os_name,
|
||||||
|
compat_Pattern,
|
||||||
compat_str,
|
compat_str,
|
||||||
compat_urllib_error,
|
compat_urllib_error,
|
||||||
compat_urllib_parse_unquote,
|
compat_urllib_parse_unquote,
|
||||||
|
@ -41,7 +42,6 @@ from ..utils import (
|
||||||
base_url,
|
base_url,
|
||||||
bug_reports_message,
|
bug_reports_message,
|
||||||
clean_html,
|
clean_html,
|
||||||
compiled_regex_type,
|
|
||||||
determine_ext,
|
determine_ext,
|
||||||
determine_protocol,
|
determine_protocol,
|
||||||
dict_get,
|
dict_get,
|
||||||
|
@ -1203,7 +1203,9 @@ class InfoExtractor(object):
|
||||||
In case of failure return a default value or raise a WARNING or a
|
In case of failure return a default value or raise a WARNING or a
|
||||||
RegexNotFoundError, depending on fatal, specifying the field name.
|
RegexNotFoundError, depending on fatal, specifying the field name.
|
||||||
"""
|
"""
|
||||||
if isinstance(pattern, (str, compat_str, compiled_regex_type)):
|
if string is None:
|
||||||
|
mobj = None
|
||||||
|
elif isinstance(pattern, (str, compat_Pattern)):
|
||||||
mobj = re.search(pattern, string, flags)
|
mobj = re.search(pattern, string, flags)
|
||||||
else:
|
else:
|
||||||
for p in pattern:
|
for p in pattern:
|
||||||
|
|
|
@ -4109,14 +4109,15 @@ class YoutubeTabBaseInfoExtractor(YoutubeBaseInfoExtractor):
|
||||||
if fatal:
|
if fatal:
|
||||||
raise ExtractorError('Unable to find selected tab')
|
raise ExtractorError('Unable to find selected tab')
|
||||||
|
|
||||||
@classmethod
|
def _extract_uploader(self, data):
|
||||||
def _extract_uploader(cls, data):
|
|
||||||
uploader = {}
|
uploader = {}
|
||||||
renderer = cls._extract_sidebar_info_renderer(data, 'playlistSidebarSecondaryInfoRenderer') or {}
|
renderer = self._extract_sidebar_info_renderer(data, 'playlistSidebarSecondaryInfoRenderer') or {}
|
||||||
owner = try_get(
|
owner = try_get(
|
||||||
renderer, lambda x: x['videoOwner']['videoOwnerRenderer']['title']['runs'][0], dict)
|
renderer, lambda x: x['videoOwner']['videoOwnerRenderer']['title']['runs'][0], dict)
|
||||||
if owner:
|
if owner:
|
||||||
uploader['uploader'] = owner.get('text')
|
owner_text = owner.get('text')
|
||||||
|
uploader['uploader'] = self._search_regex(
|
||||||
|
r'^by (.+) and \d+ others?$', owner_text, 'uploader', default=owner_text)
|
||||||
uploader['uploader_id'] = try_get(
|
uploader['uploader_id'] = try_get(
|
||||||
owner, lambda x: x['navigationEndpoint']['browseEndpoint']['browseId'], compat_str)
|
owner, lambda x: x['navigationEndpoint']['browseEndpoint']['browseId'], compat_str)
|
||||||
uploader['uploader_url'] = urljoin(
|
uploader['uploader_url'] = urljoin(
|
||||||
|
@ -5136,6 +5137,24 @@ class YoutubeTabIE(YoutubeTabBaseInfoExtractor):
|
||||||
'note': 'non-standard redirect to regional channel',
|
'note': 'non-standard redirect to regional channel',
|
||||||
'url': 'https://www.youtube.com/channel/UCwVVpHQ2Cs9iGJfpdFngePQ',
|
'url': 'https://www.youtube.com/channel/UCwVVpHQ2Cs9iGJfpdFngePQ',
|
||||||
'only_matching': True
|
'only_matching': True
|
||||||
|
}, {
|
||||||
|
'note': 'collaborative playlist (uploader name in the form "by <uploader> and x other(s)")',
|
||||||
|
'url': 'https://www.youtube.com/playlist?list=PLx-_-Kk4c89oOHEDQAojOXzEzemXxoqx6',
|
||||||
|
'info_dict': {
|
||||||
|
'id': 'PLx-_-Kk4c89oOHEDQAojOXzEzemXxoqx6',
|
||||||
|
'modified_date': '20220407',
|
||||||
|
'channel_url': 'https://www.youtube.com/channel/UCKcqXmCcyqnhgpA5P0oHH_Q',
|
||||||
|
'tags': [],
|
||||||
|
'uploader_id': 'UCKcqXmCcyqnhgpA5P0oHH_Q',
|
||||||
|
'uploader': 'pukkandan',
|
||||||
|
'availability': 'unlisted',
|
||||||
|
'channel_id': 'UCKcqXmCcyqnhgpA5P0oHH_Q',
|
||||||
|
'channel': 'pukkandan',
|
||||||
|
'description': 'Test for collaborative playlist',
|
||||||
|
'title': 'yt-dlp test - collaborative playlist',
|
||||||
|
'uploader_url': 'https://www.youtube.com/channel/UCKcqXmCcyqnhgpA5P0oHH_Q',
|
||||||
|
},
|
||||||
|
'playlist_mincount': 2
|
||||||
}]
|
}]
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
|
|
Loading…
Reference in a new issue