]>
Raphaƫl G. Git Repositories - youtubedl/blob - youtube_dl/extractor/hgtv.py
2 from __future__
import unicode_literals
4 from .common
import InfoExtractor
7 class HGTVComShowIE(InfoExtractor
):
8 IE_NAME
= 'hgtv.com:show'
9 _VALID_URL
= r
'https?://(?:www\.)?hgtv\.com/shows/[^/]+/(?P<id>[^/?#&]+)'
12 'url': 'http://www.hgtv.com/shows/flip-or-flop/flip-or-flop-full-episodes-season-4-videos',
14 'id': 'flip-or-flop-full-episodes-season-4-videos',
15 'title': 'Flip or Flop Full Episodes',
17 'playlist_mincount': 15,
19 # data-deferred-module="video"
20 'url': 'http://www.hgtv.com/shows/good-bones/episodes/an-old-victorian-house-gets-a-new-facelift',
21 'only_matching': True,
24 def _real_extract(self
, url
):
25 display_id
= self
._match
_id
(url
)
27 webpage
= self
._download
_webpage
(url
, display_id
)
29 config
= self
._parse
_json
(
31 r
'(?s)data-(?:deferred-)?module=["\']video
["\'][^>]*>.*?<script[^>]+type=["\']text
/x
-config
["\'][^>]*>(.+?)</script',
32 webpage, 'video config'),
33 display_id)['channels'][0]
36 self.url_result(video['releaseUrl'])
37 for video in config['videos'] if video.get('releaseUrl')]
39 return self.playlist_result(
40 entries, display_id, config.get('title'), config.get('description'))