diff options
| -rw-r--r-- | youtube_dl/extractor/__init__.py | 1 | ||||
| -rw-r--r-- | youtube_dl/extractor/streetvoice.py | 36 | 
2 files changed, 37 insertions, 0 deletions
| diff --git a/youtube_dl/extractor/__init__.py b/youtube_dl/extractor/__init__.py index 0b0f3be19..c41f2de0f 100644 --- a/youtube_dl/extractor/__init__.py +++ b/youtube_dl/extractor/__init__.py @@ -409,6 +409,7 @@ from .stanfordoc import StanfordOpenClassroomIE  from .steam import SteamIE  from .streamcloud import StreamcloudIE  from .streamcz import StreamCZIE +from .streetvoice import StreetVoiceIE  from .sunporno import SunPornoIE  from .swrmediathek import SWRMediathekIE  from .syfy import SyfyIE diff --git a/youtube_dl/extractor/streetvoice.py b/youtube_dl/extractor/streetvoice.py new file mode 100644 index 000000000..55ceea75b --- /dev/null +++ b/youtube_dl/extractor/streetvoice.py @@ -0,0 +1,36 @@ +# coding: utf-8 +from __future__ import unicode_literals + +from .common import InfoExtractor + + +class StreetVoiceIE(InfoExtractor): +    _VALID_URL = r'http://tw.streetvoice.com/[^/]+/songs/(?P<id>[0-9]+)/' +    _TESTS = [ +        { +            'url': 'http://tw.streetvoice.com/skippylu/songs/94440/', +            'md5': '15974627fc01a29e492c98593c2fd472', +            'info_dict': { +                'id': '94440', +                'ext': 'mp3', +                'title': '輸', +                'description': '輸 - Crispy脆樂團' +            } +        } +    ] + +    def _real_extract(self, url): +        song_id = self._match_id(url) + +        api_url = 'http://tw.streetvoice.com/music/api/song/%s/' % song_id +        info_dict = self._download_json(api_url, song_id) + +        author = info_dict['musician']['name'] +        title = info_dict['name'] +        return { +            'id': song_id, +            'ext': 'mp3', +            'title': title, +            'url': info_dict['file'], +            'description': '%s - %s' % (title, author) +        } | 
