mirror of https://github.com/yt-dlp/yt-dlp.git
run flake8
This commit is contained in:
parent
57f72370c5
commit
b3fd4b155e
|
@ -3286,7 +3286,7 @@ class YoutubeFeedsInfoExtractor(YoutubeBaseInfoExtractor):
|
||||||
"""
|
"""
|
||||||
_LOGIN_REQUIRED = True
|
_LOGIN_REQUIRED = True
|
||||||
|
|
||||||
_FEED_DATA = r'window\[\"ytInitialData\"\]\W?=\W?({.*?});'
|
_FEED_DATA = r'window\[\"ytInitialData\"\]\W?=\W?({.*?});'
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def IE_NAME(self):
|
def IE_NAME(self):
|
||||||
|
@ -3299,20 +3299,20 @@ class YoutubeFeedsInfoExtractor(YoutubeBaseInfoExtractor):
|
||||||
# The extraction process is the same as for playlists, but the regex
|
# The extraction process is the same as for playlists, but the regex
|
||||||
# for the video ids doesn't contain an index
|
# for the video ids doesn't contain an index
|
||||||
info = []
|
info = []
|
||||||
|
|
||||||
for page_num in itertools.count(1):
|
for page_num in itertools.count(1):
|
||||||
search_response = self._parse_json(self._search_regex(self._FEED_DATA, page, 'ytInitialData'), None)
|
search_response = self._parse_json(self._search_regex(self._FEED_DATA, page, 'ytInitialData'), None)
|
||||||
|
|
||||||
video_info, continuation = self._extract_video_info(search_response)
|
video_info, continuation = self._extract_video_info(search_response)
|
||||||
|
|
||||||
new_info = []
|
new_info = []
|
||||||
|
|
||||||
for v in video_info:
|
for v in video_info:
|
||||||
v_id = try_get(v, lambda x: x['videoId'])
|
v_id = try_get(v, lambda x: x['videoId'])
|
||||||
if not v_id:
|
if not v_id:
|
||||||
continue
|
continue
|
||||||
|
|
||||||
have_video = False
|
have_video = False
|
||||||
for old in info:
|
for old in info:
|
||||||
if old['videoId'] == v_id:
|
if old['videoId'] == v_id:
|
||||||
have_video = True
|
have_video = True
|
||||||
|
@ -3386,15 +3386,15 @@ class YoutubeRecommendedIE(YoutubeFeedsInfoExtractor):
|
||||||
continuation_renderer = None
|
continuation_renderer = None
|
||||||
|
|
||||||
renderers = try_get(
|
renderers = try_get(
|
||||||
initial_data,
|
initial_data,
|
||||||
lambda x: x['contents']['twoColumnBrowseResultsRenderer']['tabs'][0]['tabRenderer']['content']['richGridRenderer']['contents'])
|
lambda x: x['contents']['twoColumnBrowseResultsRenderer']['tabs'][0]['tabRenderer']['content']['richGridRenderer']['contents'])
|
||||||
|
|
||||||
for renderer in renderers:
|
for renderer in renderers:
|
||||||
vid = try_get(renderer, lambda x: x['richItemRenderer']['content']['videoRenderer'])
|
vid = try_get(renderer, lambda x: x['richItemRenderer']['content']['videoRenderer'])
|
||||||
if vid is not None:
|
if vid is not None:
|
||||||
videos.append(vid)
|
videos.append(vid)
|
||||||
continue
|
continue
|
||||||
|
|
||||||
if 'richSectionRenderer' in renderer:
|
if 'richSectionRenderer' in renderer:
|
||||||
vids = try_get(renderer, lambda x: x['richSectionRenderer']['content']['richShelfRenderer']['contents'])
|
vids = try_get(renderer, lambda x: x['richSectionRenderer']['content']['richShelfRenderer']['contents'])
|
||||||
for v in vids:
|
for v in vids:
|
||||||
|
@ -3402,12 +3402,13 @@ class YoutubeRecommendedIE(YoutubeFeedsInfoExtractor):
|
||||||
if vid is not None:
|
if vid is not None:
|
||||||
videos.append(vid)
|
videos.append(vid)
|
||||||
continue
|
continue
|
||||||
|
|
||||||
if 'continuationItemRenderer' in renderer:
|
if 'continuationItemRenderer' in renderer:
|
||||||
continuation_renderer = renderer
|
continuation_renderer = renderer
|
||||||
|
|
||||||
return videos, continuation_renderer
|
return videos, continuation_renderer
|
||||||
|
|
||||||
|
|
||||||
class YoutubeSubscriptionsIE(YoutubeFeedsInfoExtractor):
|
class YoutubeSubscriptionsIE(YoutubeFeedsInfoExtractor):
|
||||||
IE_DESC = 'YouTube.com subscriptions feed, "ytsubs" keyword (requires authentication)'
|
IE_DESC = 'YouTube.com subscriptions feed, "ytsubs" keyword (requires authentication)'
|
||||||
_VALID_URL = r'https?://(?:www\.)?youtube\.com/feed/subscriptions|:ytsubs(?:criptions)?'
|
_VALID_URL = r'https?://(?:www\.)?youtube\.com/feed/subscriptions|:ytsubs(?:criptions)?'
|
||||||
|
@ -3419,8 +3420,8 @@ class YoutubeSubscriptionsIE(YoutubeFeedsInfoExtractor):
|
||||||
continuation_renderer = None
|
continuation_renderer = None
|
||||||
|
|
||||||
renderers = try_get(
|
renderers = try_get(
|
||||||
initial_data,
|
initial_data,
|
||||||
lambda x: x['contents']['twoColumnBrowseResultsRenderer']['tabs'][0]['tabRenderer']['content']['sectionListRenderer']['contents'])
|
lambda x: x['contents']['twoColumnBrowseResultsRenderer']['tabs'][0]['tabRenderer']['content']['sectionListRenderer']['contents'])
|
||||||
for renderer in renderers:
|
for renderer in renderers:
|
||||||
for item in try_get(renderer, lambda x: x['itemSectionRenderer']['contents'][0]['shelfRenderer']['content']['gridRenderer']['items']):
|
for item in try_get(renderer, lambda x: x['itemSectionRenderer']['contents'][0]['shelfRenderer']['content']['gridRenderer']['items']):
|
||||||
vid = try_get(item, lambda x: x['gridVideoRenderer'])
|
vid = try_get(item, lambda x: x['gridVideoRenderer'])
|
||||||
|
@ -3432,6 +3433,7 @@ class YoutubeSubscriptionsIE(YoutubeFeedsInfoExtractor):
|
||||||
|
|
||||||
return videos, continuation_renderer
|
return videos, continuation_renderer
|
||||||
|
|
||||||
|
|
||||||
class YoutubeHistoryIE(YoutubeFeedsInfoExtractor):
|
class YoutubeHistoryIE(YoutubeFeedsInfoExtractor):
|
||||||
IE_DESC = 'Youtube watch history, ":ythistory" for short (requires authentication)'
|
IE_DESC = 'Youtube watch history, ":ythistory" for short (requires authentication)'
|
||||||
_VALID_URL = r'https?://(?:www\.)?youtube\.com/feed/history|:ythistory'
|
_VALID_URL = r'https?://(?:www\.)?youtube\.com/feed/history|:ythistory'
|
||||||
|
@ -3441,10 +3443,10 @@ class YoutubeHistoryIE(YoutubeFeedsInfoExtractor):
|
||||||
def _extract_video_info(self, initial_data):
|
def _extract_video_info(self, initial_data):
|
||||||
videos = []
|
videos = []
|
||||||
continuation_renderer = None
|
continuation_renderer = None
|
||||||
|
|
||||||
renderers = try_get(
|
renderers = try_get(
|
||||||
initial_data,
|
initial_data,
|
||||||
lambda x: x['contents']['twoColumnBrowseResultsRenderer']['tabs'][0]['tabRenderer']['content']['sectionListRenderer']['contents'])
|
lambda x: x['contents']['twoColumnBrowseResultsRenderer']['tabs'][0]['tabRenderer']['content']['sectionListRenderer']['contents'])
|
||||||
for renderer in renderers:
|
for renderer in renderers:
|
||||||
vid = try_get(renderer, lambda x: x['itemSectionRenderer']['contents'][0]['videoRenderer'])
|
vid = try_get(renderer, lambda x: x['itemSectionRenderer']['contents'][0]['videoRenderer'])
|
||||||
if vid is not None:
|
if vid is not None:
|
||||||
|
@ -3455,6 +3457,7 @@ class YoutubeHistoryIE(YoutubeFeedsInfoExtractor):
|
||||||
|
|
||||||
return videos, continuation_renderer
|
return videos, continuation_renderer
|
||||||
|
|
||||||
|
|
||||||
class YoutubeTruncatedURLIE(InfoExtractor):
|
class YoutubeTruncatedURLIE(InfoExtractor):
|
||||||
IE_NAME = 'youtube:truncated_url'
|
IE_NAME = 'youtube:truncated_url'
|
||||||
IE_DESC = False # Do not list
|
IE_DESC = False # Do not list
|
||||||
|
|
Loading…
Reference in New Issue