diff options
| author | Sergey M․ <dstftw@gmail.com> | 2015-04-10 23:36:28 +0600 | 
|---|---|---|
| committer | Sergey M․ <dstftw@gmail.com> | 2015-04-10 23:36:28 +0600 | 
| commit | 66ee7b3234482ddcb24849d3ab64db382fff5bfd (patch) | |
| tree | 89ddea462a8e4320aedcd91b0251bc7314ea4fce /youtube_dl/extractor/ted.py | |
| parent | cd47a628fcfb4ec49d0559bdedf792d99a52d53d (diff) | |
[ted] Extract all formats (Closes #5397)
Diffstat (limited to 'youtube_dl/extractor/ted.py')
| -rw-r--r-- | youtube_dl/extractor/ted.py | 51 | 
1 files changed, 37 insertions, 14 deletions
| diff --git a/youtube_dl/extractor/ted.py b/youtube_dl/extractor/ted.py index 4cec06f8b..a2dc14c2b 100644 --- a/youtube_dl/extractor/ted.py +++ b/youtube_dl/extractor/ted.py @@ -5,9 +5,8 @@ import re  from .common import InfoExtractor -from ..compat import ( -    compat_str, -) +from ..compat import compat_str +from ..utils import int_or_none  class TEDIE(InfoExtractor): @@ -170,17 +169,41 @@ class TEDIE(InfoExtractor):                  finfo = self._NATIVE_FORMATS.get(f['format_id'])                  if finfo:                      f.update(finfo) -        else: -            # Use rtmp downloads -            formats = [{ -                'format_id': f['name'], -                'url': talk_info['streamer'], -                'play_path': f['file'], -                'ext': 'flv', -                'width': f['width'], -                'height': f['height'], -                'tbr': f['bitrate'], -            } for f in talk_info['resources']['rtmp']] + +        for format_id, resources in talk_info['resources'].items(): +            if format_id == 'h264': +                for resource in resources: +                    bitrate = int_or_none(resource.get('bitrate')) +                    formats.append({ +                        'url': resource['file'], +                        'format_id': '%s-%sk' % (format_id, bitrate), +                        'tbr': bitrate, +                    }) +            elif format_id == 'rtmp': +                streamer = talk_info.get('streamer') +                if not streamer: +                    continue +                for resource in resources: +                    formats.append({ +                        'format_id': '%s-%s' % (format_id, resource.get('name')), +                        'url': streamer, +                        'play_path': resource['file'], +                        'ext': 'flv', +                        'width': int_or_none(resource.get('width')), +                        'height': int_or_none(resource.get('height')), +                        'tbr': int_or_none(resource.get('bitrate')), +                    }) +            elif format_id == 'hls': +                formats.extend(self._extract_m3u8_formats( +                    resources.get('stream'), video_name, 'mp4', m3u8_id=format_id)) + +        audio_download = talk_info.get('audioDownload') +        if audio_download: +            formats.append({ +                'url': audio_download, +                'format_id': 'audio', +            }) +          self._sort_formats(formats)          video_id = compat_str(talk_info['id']) | 
