mirror of
https://github.com/yt-dlp/yt-dlp.git
synced 2024-11-30 03:33:02 +00:00
[arte:+7] Fix extraction for react-based layout
This commit is contained in:
parent
0f425e65ec
commit
9654fc875b
1 changed files with 14 additions and 4 deletions
|
@ -102,10 +102,20 @@ def find_iframe_url(webpage, default=NO_DEFAULT):
|
||||||
iframe_url = find_iframe_url(webpage, None)
|
iframe_url = find_iframe_url(webpage, None)
|
||||||
if not iframe_url:
|
if not iframe_url:
|
||||||
embed_url = self._html_search_regex(
|
embed_url = self._html_search_regex(
|
||||||
r'arte_vp_url_oembed=\'([^\']+?)\'', webpage, 'embed url')
|
r'arte_vp_url_oembed=\'([^\']+?)\'', webpage, 'embed url', default=None)
|
||||||
|
if embed_url:
|
||||||
player = self._download_json(
|
player = self._download_json(
|
||||||
embed_url, video_id, 'Downloading player page')
|
embed_url, video_id, 'Downloading player page')
|
||||||
iframe_url = find_iframe_url(player['html'])
|
iframe_url = find_iframe_url(player['html'])
|
||||||
|
# en and es URLs produce react-based pages with different layout (e.g.
|
||||||
|
# http://www.arte.tv/guide/en/053330-002-A/carnival-italy?zone=world)
|
||||||
|
if not iframe_url:
|
||||||
|
embed_html = self._parse_json(
|
||||||
|
self._search_regex(
|
||||||
|
r'program\s*:\s*({.+?["\']embed_html["\'].+?}),?\s*\n',
|
||||||
|
webpage, 'program'),
|
||||||
|
video_id)['embed_html']
|
||||||
|
iframe_url= find_iframe_url(embed_html)
|
||||||
json_url = compat_parse_qs(
|
json_url = compat_parse_qs(
|
||||||
compat_urllib_parse_urlparse(iframe_url).query)['json_url'][0]
|
compat_urllib_parse_urlparse(iframe_url).query)['json_url'][0]
|
||||||
return self._extract_from_json_url(json_url, video_id, lang)
|
return self._extract_from_json_url(json_url, video_id, lang)
|
||||||
|
|
Loading…
Reference in a new issue