mirror of
https://github.com/yt-dlp/yt-dlp.git
synced 2024-12-24 20:25:52 +01:00
[youtube] Fix hashtag continuation
Eg: https://www.youtube.com/hashtag/youtube :ci skip dl
This commit is contained in:
parent
c2934512c2
commit
9ba5705ac0
@ -58,7 +58,7 @@ class YoutubeBaseInfoExtractor(InfoExtractor):
|
||||
_TFA_URL = 'https://accounts.google.com/_/signin/challenge?hl=en&TL={0}'
|
||||
|
||||
_RESERVED_NAMES = (
|
||||
r'embed|e|watch_popup|channel|c|user|playlist|watch|w|v|movies|results|shared|'
|
||||
r'embed|e|watch_popup|channel|c|user|playlist|watch|w|v|movies|results|shared|hashtag|'
|
||||
r'storefront|oops|index|account|reporthistory|t/terms|about|upload|signin|logout|'
|
||||
r'feed/(?:watch_later|history|subscriptions|library|trending|recommended)')
|
||||
|
||||
@ -2141,7 +2141,7 @@ class YoutubeTabIE(YoutubeBaseInfoExtractor):
|
||||
(?:
|
||||
(?:channel|c|user)/|
|
||||
(?P<not_channel>
|
||||
feed/|
|
||||
feed/|hashtag/|
|
||||
(?:playlist|watch)\?.*?\blist=
|
||||
)|
|
||||
(?!(?:%s)\b) # Direct URLs
|
||||
@ -2775,6 +2775,7 @@ def extract_entries(parent_renderer): # this needs to called again for continua
|
||||
'gridVideoRenderer': (self._grid_entries, 'items'),
|
||||
'playlistVideoRenderer': (self._playlist_entries, 'contents'),
|
||||
'itemSectionRenderer': (self._playlist_entries, 'contents'),
|
||||
'richItemRenderer': (extract_entries, 'contents'), # for hashtag
|
||||
}
|
||||
continuation_items = try_get(
|
||||
response, lambda x: x['onResponseReceivedActions'][0]['appendContinuationItemsAction']['continuationItems'], list)
|
||||
@ -2784,9 +2785,10 @@ def extract_entries(parent_renderer): # this needs to called again for continua
|
||||
if key not in known_renderers:
|
||||
continue
|
||||
video_items_renderer = {known_renderers[key][1]: continuation_items}
|
||||
continuation_list = [None]
|
||||
for entry in known_renderers[key][0](video_items_renderer):
|
||||
yield entry
|
||||
continuation = self._extract_continuation(video_items_renderer)
|
||||
continuation = continuation_list[0] or self._extract_continuation(video_items_renderer)
|
||||
break
|
||||
if video_items_renderer:
|
||||
continue
|
||||
|
Loading…
Reference in New Issue
Block a user