]>
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
),