mirror of
https://codeberg.org/polarisfm/youtube-dl
synced 2024-11-26 18:34:32 +01:00
[ted] Style fixes
This commit is contained in:
parent
ca1fee34f2
commit
bacac173a9
@ -12,22 +12,25 @@ from ..utils import (
|
|||||||
|
|
||||||
|
|
||||||
class TEDIE(SubtitlesInfoExtractor):
|
class TEDIE(SubtitlesInfoExtractor):
|
||||||
_VALID_URL=r'''(?x)http://www\.ted\.com/
|
_VALID_URL = r'''(?x)http://www\.ted\.com/
|
||||||
(
|
(
|
||||||
(?P<type_playlist>playlists(?:/\d+)?) # We have a playlist
|
(?P<type_playlist>playlists(?:/\d+)?) # We have a playlist
|
||||||
|
|
|
|
||||||
((?P<type_talk>talks)) # We have a simple talk
|
((?P<type_talk>talks)) # We have a simple talk
|
||||||
)
|
)
|
||||||
(/lang/(.*?))? # The url may contain the language
|
(/lang/(.*?))? # The url may contain the language
|
||||||
/(?P<name>\w+) # Here goes the name and then ".html"
|
/(?P<name>\w+) # Here goes the name and then ".html"
|
||||||
'''
|
'''
|
||||||
_TEST = {
|
_TEST = {
|
||||||
'url': 'http://www.ted.com/talks/dan_dennett_on_our_consciousness.html',
|
'url': 'http://www.ted.com/talks/dan_dennett_on_our_consciousness.html',
|
||||||
'file': '102.mp4',
|
'file': '102.mp4',
|
||||||
'md5': '4ea1dada91e4174b53dac2bb8ace429d',
|
'md5': '4ea1dada91e4174b53dac2bb8ace429d',
|
||||||
'info_dict': {
|
'info_dict': {
|
||||||
'title': 'The illusion of consciousness',
|
'title': 'The illusion of consciousness',
|
||||||
'description': 'Philosopher Dan Dennett makes a compelling argument that not only don\'t we understand our own consciousness, but that half the time our brains are actively fooling us.',
|
'description': ('Philosopher Dan Dennett makes a compelling '
|
||||||
|
'argument that not only don\'t we understand our own '
|
||||||
|
'consciousness, but that half the time our brains are '
|
||||||
|
'actively fooling us.'),
|
||||||
'uploader': 'Dan Dennett',
|
'uploader': 'Dan Dennett',
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -39,18 +42,18 @@ class TEDIE(SubtitlesInfoExtractor):
|
|||||||
}
|
}
|
||||||
|
|
||||||
def _extract_info(self, webpage):
|
def _extract_info(self, webpage):
|
||||||
info_json = self._search_regex(r'q\("\w+.init",({.+})\)</script>', webpage, 'info json')
|
info_json = self._search_regex(r'q\("\w+.init",({.+})\)</script>',
|
||||||
|
webpage, 'info json')
|
||||||
return json.loads(info_json)
|
return json.loads(info_json)
|
||||||
|
|
||||||
def _real_extract(self, url):
|
def _real_extract(self, url):
|
||||||
m=re.match(self._VALID_URL, url, re.VERBOSE)
|
m = re.match(self._VALID_URL, url, re.VERBOSE)
|
||||||
|
name = m.group('name')
|
||||||
if m.group('type_talk'):
|
if m.group('type_talk'):
|
||||||
return self._talk_info(url)
|
return self._talk_info(url, name)
|
||||||
else :
|
else:
|
||||||
name=m.group('name')
|
|
||||||
return self._playlist_videos_info(url, name)
|
return self._playlist_videos_info(url, name)
|
||||||
|
|
||||||
|
|
||||||
def _playlist_videos_info(self, url, name):
|
def _playlist_videos_info(self, url, name):
|
||||||
'''Returns the videos of the playlist'''
|
'''Returns the videos of the playlist'''
|
||||||
|
|
||||||
@ -68,11 +71,8 @@ class TEDIE(SubtitlesInfoExtractor):
|
|||||||
playlist_id=compat_str(playlist_info['id']),
|
playlist_id=compat_str(playlist_info['id']),
|
||||||
playlist_title=playlist_info['title'])
|
playlist_title=playlist_info['title'])
|
||||||
|
|
||||||
def _talk_info(self, url, video_id=0):
|
def _talk_info(self, url, video_name):
|
||||||
"""Return the video for the talk in the url"""
|
webpage = self._download_webpage(url, video_name)
|
||||||
m = re.match(self._VALID_URL, url)
|
|
||||||
video_name = m.group('name')
|
|
||||||
webpage = self._download_webpage(url, video_id, 'Downloading \"%s\" page' % video_name)
|
|
||||||
self.report_extraction(video_name)
|
self.report_extraction(video_name)
|
||||||
|
|
||||||
talk_info = self._extract_info(webpage)['talks'][0]
|
talk_info = self._extract_info(webpage)['talks'][0]
|
||||||
|
Loading…
Reference in New Issue
Block a user