mirror of
https://github.com/yt-dlp/yt-dlp.git
synced 2025-08-15 08:58:28 +00:00
Prevent '"NoneType" object has no attribute "get"' exception and and missing dict keys.
This commit is contained in:
parent
bfdfb57fd6
commit
b73250f275
@ -126,17 +126,24 @@ def _real_extract(self, url):
|
|||||||
raise ExtractorError(str(e), expected=True)
|
raise ExtractorError(str(e), expected=True)
|
||||||
if json_info.get('status') != 200:
|
if json_info.get('status') != 200:
|
||||||
raise ExtractorError('Json download error. Status code: %s' % str(json_info.get('status')), expected=True)
|
raise ExtractorError('Json download error. Status code: %s' % str(json_info.get('status')), expected=True)
|
||||||
media_info = json_info['data']['playlist']['medialist'][0]
|
try:
|
||||||
formats, subtitles = self._extract_m3u8_formats_and_subtitles(
|
media_info = json_info.get('data').get('playlist').get('medialist')[0]
|
||||||
media_info['sources']['m3u8']['auto'], video_id, 'mp4', m3u8_id='hls',
|
except (KeyError, AttributeError, TypeError) as e:
|
||||||
)
|
raise ExtractorError("media_info get error: %s " % str(e), expected=True)
|
||||||
|
try:
|
||||||
|
formats, subtitles = self._extract_m3u8_formats_and_subtitles(
|
||||||
|
media_info.get('sources').get('m3u8').get('auto'), video_id, 'mp4', m3u8_id='hls',
|
||||||
|
)
|
||||||
|
res = {
|
||||||
|
'id': video_id,
|
||||||
|
'title': media_info.get('title'),
|
||||||
|
'thumbnail': media_info.get('pictures').get('16:9'),
|
||||||
|
'formats': formats,
|
||||||
|
'subtitles': subtitles,
|
||||||
|
'is_live': json_info.get('data').get('playlist').get('type') == 'live',
|
||||||
|
'duration': int_or_none(media_info.get('duration')),
|
||||||
|
}
|
||||||
|
except (KeyError, AttributeError, TypeError) as e:
|
||||||
|
raise ExtractorError("Result error: %s" % str(e), expected=True)
|
||||||
|
|
||||||
return {
|
return res
|
||||||
'id': video_id,
|
|
||||||
'title': media_info.get('title'),
|
|
||||||
'thumbnail': media_info['pictures']['16:9'],
|
|
||||||
'formats': formats,
|
|
||||||
'subtitles': subtitles,
|
|
||||||
'is_live': json_info['data']['playlist']['type'] == 'live',
|
|
||||||
'duration': int_or_none(media_info.get('duration')),
|
|
||||||
}
|
|
||||||
|
Loading…
Reference in New Issue
Block a user