|
|
|
@ -6,6 +6,8 @@ from .common import InfoExtractor
|
|
|
|
|
from ..utils import (
|
|
|
|
|
parse_duration,
|
|
|
|
|
int_or_none,
|
|
|
|
|
xpath_text,
|
|
|
|
|
xpath_attr,
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -26,7 +28,7 @@ class NBAIE(InfoExtractor):
|
|
|
|
|
}, {
|
|
|
|
|
'url': 'http://www.nba.com/video/games/hornets/2014/12/05/0021400276-nyk-cha-play5.nba/',
|
|
|
|
|
'only_matching': True,
|
|
|
|
|
},{
|
|
|
|
|
}, {
|
|
|
|
|
'url': 'http://watch.nba.com/video/channels/playoffs/2015/05/20/0041400301-cle-atl-recap.nba',
|
|
|
|
|
'md5': 'b2b39b81cf28615ae0c3360a3f9668c4',
|
|
|
|
|
'info_dict': {
|
|
|
|
@ -43,11 +45,11 @@ class NBAIE(InfoExtractor):
|
|
|
|
|
def _real_extract(self, url):
|
|
|
|
|
path, video_id = re.match(self._VALID_URL, url).groups()
|
|
|
|
|
video_info = self._download_xml('http://www.nba.com/%s.xml' % path, video_id)
|
|
|
|
|
video_id = video_info.find('slug').text
|
|
|
|
|
title = video_info.find('headline').text
|
|
|
|
|
description = video_info.find('description').text
|
|
|
|
|
duration = parse_duration(video_info.find('length').text)
|
|
|
|
|
timestamp = int_or_none(video_info.find('dateCreated').attrib.get('uts'))
|
|
|
|
|
video_id = xpath_text(video_info, 'slug')
|
|
|
|
|
title = xpath_text(video_info, 'headline')
|
|
|
|
|
description = xpath_text(video_info, 'description')
|
|
|
|
|
duration = parse_duration(xpath_text(video_info, 'length'))
|
|
|
|
|
timestamp = int_or_none(xpath_attr(video_info, 'dateCreated', 'uts'))
|
|
|
|
|
|
|
|
|
|
thumbnails = []
|
|
|
|
|
for image in video_info.find('images'):
|
|
|
|
|