]>
Raphaƫl G. Git Repositories - youtubedl/blob - youtube_dl/extractor/plays.py
   2 from __future__ 
import unicode_literals
 
   6 from .common 
import InfoExtractor
 
   7 from ..utils 
import int_or_none
 
  10 class PlaysTVIE(InfoExtractor
): 
  11     _VALID_URL 
= r
'https?://(?:www\.)?plays\.tv/video/(?P<id>[0-9a-f]{18})' 
  13         'url': 'http://plays.tv/video/56af17f56c95335490/when-you-outplay-the-azir-wall', 
  14         'md5': 'dfeac1198506652b5257a62762cec7bc', 
  16             'id': '56af17f56c95335490', 
  18             'title': 'When you outplay the Azir wall', 
  19             'description': 'Posted by Bjergsen', 
  23     def _real_extract(self
, url
): 
  24         video_id 
= self
._match
_id
(url
) 
  25         webpage 
= self
._download
_webpage
(url
, video_id
) 
  27         title 
= self
._og
_search
_title
(webpage
) 
  28         content 
= self
._parse
_json
( 
  30                 r
'R\.bindContent\(({.+?})\);', webpage
, 
  31                 'content'), video_id
)['content'] 
  32         mpd_url
, sources 
= re
.search( 
  33             r
'(?s)<video[^>]+data-mpd="([^"]+)"[^>]*>(.+?)</video>', 
  35         formats 
= self
._extract
_mpd
_formats
( 
  36             self
._proto
_relative
_url
(mpd_url
), video_id
, mpd_id
='DASH') 
  37         for format_id
, height
, format_url 
in re
.findall(r
'<source\s+res="((\d+)h?)"\s+src="([^"]+)"', sources
): 
  39                 'url': self
._proto
_relative
_url
(format_url
), 
  40                 'format_id': 'http-' + format_id
, 
  41                 'height': int_or_none(height
), 
  43         self
._sort
_formats
(formats
) 
  48             'description': self
._og
_search
_description
(webpage
), 
  49             'thumbnail': self
._og
_search
_thumbnail
(webpage
),