diff options
| author | Sergey M <dstftw@gmail.com> | 2016-01-31 04:36:33 +0600 | 
|---|---|---|
| committer | Sergey M <dstftw@gmail.com> | 2016-01-31 04:36:33 +0600 | 
| commit | 181cf24bc0e011138d94a3431166f77fb01d2c3c (patch) | |
| tree | 5255c361de9f8ffccba7a77cbf2b5c141a536f95 | |
| parent | db9b1dbcd918bee41b3b38f1f1106ad5dec07bb7 (diff) | |
| parent | 89f2602880198b94f98bc41109771a52105e3cf8 (diff) | |
Merge pull request #8376 from rrooij/schooltv
[schooltv] Add extractor for SchoolTV playlists
| -rw-r--r-- | youtube_dl/extractor/__init__.py | 1 | ||||
| -rw-r--r-- | youtube_dl/extractor/npo.py | 31 | 
2 files changed, 32 insertions, 0 deletions
| diff --git a/youtube_dl/extractor/__init__.py b/youtube_dl/extractor/__init__.py index e15495ec8..dbdfb86c0 100644 --- a/youtube_dl/extractor/__init__.py +++ b/youtube_dl/extractor/__init__.py @@ -483,6 +483,7 @@ from .npo import (      NPOLiveIE,      NPORadioIE,      NPORadioFragmentIE, +    SchoolTVIE,      VPROIE,      WNLIE  ) diff --git a/youtube_dl/extractor/npo.py b/youtube_dl/extractor/npo.py index 7cd5c9303..a4363c16e 100644 --- a/youtube_dl/extractor/npo.py +++ b/youtube_dl/extractor/npo.py @@ -406,6 +406,37 @@ class NPORadioFragmentIE(InfoExtractor):          } +class SchoolTVIE(InfoExtractor): +    IE_NAME = 'schooltv' +    _VALID_URL = r'https?://(?:www\.)?schooltv\.nl/video/(?P<id>[^/?#&]+)' + +    _TEST = { +        'url': 'http://www.schooltv.nl/video/ademhaling-de-hele-dag-haal-je-adem-maar-wat-gebeurt-er-dan-eigenlijk-in-je-lichaam/', +        'info_dict': { +            'id': 'WO_NTR_429477', +            'display_id': 'ademhaling-de-hele-dag-haal-je-adem-maar-wat-gebeurt-er-dan-eigenlijk-in-je-lichaam', +            'title': 'Ademhaling: De hele dag haal je adem. Maar wat gebeurt er dan eigenlijk in je lichaam?', +            'ext': 'mp4', +            'description': 'md5:abfa0ff690adb73fd0297fd033aaa631' +        }, +        'params': { +            # Skip because of m3u8 download +            'skip_download': True +        } +    } + +    def _real_extract(self, url): +        display_id = self._match_id(url) +        webpage = self._download_webpage(url, display_id) +        video_id = self._search_regex(r'data-mid="([^"]+)"', webpage, 'video_id') +        return { +            '_type': 'url_transparent', +            'ie_key': 'NPO', +            'url': 'npo:%s' % video_id, +            'display_id': display_id +        } + +  class VPROIE(NPOIE):      IE_NAME = 'vpro'      _VALID_URL = r'https?://(?:www\.)?(?:tegenlicht\.)?vpro\.nl/(?:[^/]+/){2,}(?P<id>[^/]+)\.html' | 
