diff options
author | George Schizas <gschizas@gmail.com> | 2020-08-11 12:20:47 +0300 |
---|---|---|
committer | George Schizas <gschizas@gmail.com> | 2020-08-11 12:20:47 +0300 |
commit | edd83104b432a971feb86c69c4963dc67cc3dfc0 (patch) | |
tree | 7edfd4572ea0406ac14a9fe236e5dc1d7c2ddba0 | |
parent | a4ed50bb84658b7e77cbb37597c36fa62a9acd4b (diff) | |
download | hypervideo-pre-edd83104b432a971feb86c69c4963dc67cc3dfc0.tar.lz hypervideo-pre-edd83104b432a971feb86c69c4963dc67cc3dfc0.tar.xz hypervideo-pre-edd83104b432a971feb86c69c4963dc67cc3dfc0.zip |
Use initial data from JS instead to get chapters
There are probably a lot more useful data in there.
-rw-r--r-- | youtube_dl/extractor/youtube.py | 14 |
1 files changed, 4 insertions, 10 deletions
diff --git a/youtube_dl/extractor/youtube.py b/youtube_dl/extractor/youtube.py index b35bf03aa..03b726942 100644 --- a/youtube_dl/extractor/youtube.py +++ b/youtube_dl/extractor/youtube.py @@ -1661,21 +1661,15 @@ class YoutubeIE(YoutubeBaseInfoExtractor): def _extract_chapters_from_json(self, webpage, video_id, duration): if not webpage: return - player = self._parse_json( + initial_data = self._parse_json( self._search_regex( - r'RELATED_PLAYER_ARGS["\']\s*:\s*({.+})\s*,?\s*\n', webpage, + r'window\["ytInitialData"\] = (.+);\n', webpage, 'player args', default='{}'), video_id, fatal=False) - if not player or not isinstance(player, dict): - return - watch_next_response = player.get('watch_next_response') - if not isinstance(watch_next_response, compat_str): - return - response = self._parse_json(watch_next_response, video_id, fatal=False) - if not response or not isinstance(response, dict): + if not initial_data or not isinstance(initial_data, dict): return chapters_list = try_get( - response, + initial_data, lambda x: x['playerOverlays'] ['playerOverlayRenderer'] ['decoratedPlayerBarRenderer'] |