1
0
mirror of https://github.com/l1ving/youtube-dl synced 2025-01-03 20:22:54 +08:00
youtube-dl/youtube_dl/extractor/bellmedia.py

76 lines
2.5 KiB
Python
Raw Normal View History

2016-07-01 01:21:47 +08:00
# coding: utf-8
from __future__ import unicode_literals
import re
2016-07-01 01:21:47 +08:00
from .common import InfoExtractor
2016-09-15 15:12:12 +08:00
class BellMediaIE(InfoExtractor):
_VALID_URL = r'''(?x)https?://(?:www\.)?
(?P<domain>
(?:
ctv|
tsn|
bnn|
thecomedynetwork|
discovery|
discoveryvelocity|
sciencechannel|
investigationdiscovery|
animalplanet|
bravo|
mtv|
space
)\.ca|
much\.com
)/.*?(?:\bvid=|-vid|~|%7E|/(?:episode)?)(?P<id>[0-9]{6})'''
2016-07-01 01:21:47 +08:00
_TESTS = [{
'url': 'http://www.ctv.ca/video/player?vid=706966',
'md5': 'ff2ebbeae0aa2dcc32a830c3fd69b7b0',
'info_dict': {
'id': '706966',
'ext': 'mp4',
'title': 'Larry Day and Richard Jutras on the TIFF red carpet of \'Stonewall\'',
'description': 'etalk catches up with Larry Day and Richard Jutras on the TIFF red carpet of "Stonewall”.',
'upload_date': '20150919',
'timestamp': 1442624700,
},
'expected_warnings': ['HTTP Error 404'],
}, {
'url': 'http://www.thecomedynetwork.ca/video/player?vid=923582',
'only_matching': True,
}, {
'url': 'http://www.tsn.ca/video/expectations-high-for-milos-raonic-at-us-open~939549',
'only_matching': True,
}, {
'url': 'http://www.bnn.ca/video/berman-s-call-part-two-viewer-questions~939654',
'only_matching': True,
}, {
'url': 'http://www.ctv.ca/YourMorning/Video/S1E6-Monday-August-29-2016-vid938009',
'only_matching': True,
2016-09-15 15:12:12 +08:00
}, {
'url': 'http://www.much.com/shows/atmidnight/episode948007/tuesday-september-13-2016',
'only_matching': True,
}, {
'url': 'http://www.much.com/shows/the-almost-impossible-gameshow/928979/episode-6',
'only_matching': True,
2016-07-01 01:21:47 +08:00
}]
2016-09-15 15:12:12 +08:00
_DOMAINS = {
'thecomedynetwork': 'comedy',
'discoveryvelocity': 'discvel',
'sciencechannel': 'discsci',
'investigationdiscovery': 'invdisc',
'animalplanet': 'aniplan',
}
2016-07-01 01:21:47 +08:00
def _real_extract(self, url):
domain, video_id = re.match(self._VALID_URL, url).groups()
2016-09-15 15:12:12 +08:00
domain = domain.split('.')[0]
2016-07-01 01:21:47 +08:00
return {
'_type': 'url_transparent',
'id': video_id,
2016-09-15 15:12:12 +08:00
'url': '9c9media:%s_web:%s' % (self._DOMAINS.get(domain, domain), video_id),
2016-07-01 01:21:47 +08:00
'ie_key': 'NineCNineMedia',
}