diff options
| author | Sergey M․ <dstftw@gmail.com> | 2014-12-31 18:03:51 +0600 | 
|---|---|---|
| committer | Sergey M․ <dstftw@gmail.com> | 2014-12-31 18:03:51 +0600 | 
| commit | 1931a73f392698d01d148f69e612391ad2d7138d (patch) | |
| tree | 1579de52f9918f1ed520b4459cca9116de253134 | |
| parent | 966ea3aebde5968c3ca1b655bac2e91f6bcea466 (diff) | |
[echomsk] Add extractor (Closes #4600)
| -rw-r--r-- | youtube_dl/extractor/__init__.py | 1 | ||||
| -rw-r--r-- | youtube_dl/extractor/echomsk.py | 46 | 
2 files changed, 47 insertions, 0 deletions
| diff --git a/youtube_dl/extractor/__init__.py b/youtube_dl/extractor/__init__.py index c15786ad7..45b50792e 100644 --- a/youtube_dl/extractor/__init__.py +++ b/youtube_dl/extractor/__init__.py @@ -99,6 +99,7 @@ from .discovery import DiscoveryIE  from .divxstage import DivxStageIE  from .dropbox import DropboxIE  from .ebaumsworld import EbaumsWorldIE +from .echomsk import EchoMskIE  from .ehow import EHowIE  from .eighttracks import EightTracksIE  from .einthusan import EinthusanIE diff --git a/youtube_dl/extractor/echomsk.py b/youtube_dl/extractor/echomsk.py new file mode 100644 index 000000000..d2d94049d --- /dev/null +++ b/youtube_dl/extractor/echomsk.py @@ -0,0 +1,46 @@ +# coding: utf-8 +from __future__ import unicode_literals + +import re + +from .common import InfoExtractor + + +class EchoMskIE(InfoExtractor): +    _VALID_URL = r'http://(?:www\.)?echo\.msk\.ru/sounds/(?P<id>\d+)' +    _TEST = { +        'url': 'http://www.echo.msk.ru/sounds/1464134.html', +        'md5': '2e44b3b78daff5b458e4dbc37f191f7c', +        'info_dict': { +            'id': '1464134', +            'ext': 'mp3', +            'title': 'Особое мнение - 29 декабря 2014, 19:08', +        }, +    } + +    def _real_extract(self, url): +        video_id = self._match_id(url) + +        webpage = self._download_webpage(url, video_id) + +        audio_url = self._search_regex( +            r'<a rel="mp3" href="([^"]+)">', webpage, 'audio URL') + +        title = self._html_search_regex( +            r'<a href="/programs/[^"]+" target="_blank">([^<]+)</a>', +            webpage, 'title') + +        air_date = self._html_search_regex( +            r'(?s)<div class="date">(.+?)</div>', +            webpage, 'date', fatal=False, default=None) + +        if air_date: +            air_date = re.sub(r'(\s)\1+', r'\1', air_date) +            if air_date: +                title = '%s - %s' % (title, air_date) + +        return { +            'id': video_id, +            'url': audio_url, +            'title': title, +        } | 
