Fix python2 compatibility and title extraction

pull/8/head
xarantolus 4 years ago
parent f536080701
commit 299056ad52

@ -3325,7 +3325,7 @@ class YoutubeFeedsInfoExtractor(YoutubeBaseInfoExtractor):
def _find_videos_in_json(self, extracted): def _find_videos_in_json(self, extracted):
videos = [] videos = []
continuation = None c = {}
def _real_find(obj): def _real_find(obj):
if obj is None or isinstance(obj, str): if obj is None or isinstance(obj, str):
@ -3341,8 +3341,7 @@ class YoutubeFeedsInfoExtractor(YoutubeBaseInfoExtractor):
return return
if "nextContinuationData" in obj: if "nextContinuationData" in obj:
nonlocal continuation c["continuation"] = obj["nextContinuationData"]
continuation = obj["nextContinuationData"]
return return
for _, o in obj.items(): for _, o in obj.items():
@ -3350,7 +3349,7 @@ class YoutubeFeedsInfoExtractor(YoutubeBaseInfoExtractor):
_real_find(extracted) _real_find(extracted)
return videos, continuation return videos, try_get(c, lambda x: x["continuation"])
def _entries(self, page): def _entries(self, page):
info = [] info = []
@ -3384,7 +3383,7 @@ class YoutubeFeedsInfoExtractor(YoutubeBaseInfoExtractor):
info.extend(new_info) info.extend(new_info)
for video in new_info: for video in new_info:
yield self.url_result(try_get(video, lambda x: x['videoId']), YoutubeIE.ie_key(), video_title=try_get(video, lambda x: x['title']['simpleText'])) yield self.url_result(try_get(video, lambda x: x['videoId']), YoutubeIE.ie_key(), video_title=try_get(video, lambda x: x['title']['runs'][0]['text']))
if not continuation: if not continuation:
break break

Loading…
Cancel
Save