]>
Commit | Line | Data |
---|---|---|
21f63302 | 1 | from .common import InfoExtractor |
a1d9f6c5 | 2 | from ..utils import unescapeHTML |
21f63302 YCH |
3 | |
4 | ||
5 | class BaiduVideoIE(InfoExtractor): | |
446e7645 | 6 | IE_DESC = '百度视频' |
5886b38d | 7 | _VALID_URL = r'https?://v\.baidu\.com/(?P<type>[a-z]+)/(?P<id>\d+)\.htm' |
21f63302 YCH |
8 | _TESTS = [{ |
9 | 'url': 'http://v.baidu.com/comic/1069.htm?frp=bdbrand&q=%E4%B8%AD%E5%8D%8E%E5%B0%8F%E5%BD%93%E5%AE%B6', | |
10 | 'info_dict': { | |
11 | 'id': '1069', | |
957e0db1 | 12 | 'title': '中华小当家 TV版国语', |
a1d9f6c5 | 13 | 'description': 'md5:51be07afe461cf99fa61231421b5397c', |
21f63302 YCH |
14 | }, |
15 | 'playlist_count': 52, | |
16 | }, { | |
17 | 'url': 'http://v.baidu.com/show/11595.htm?frp=bdbrand', | |
18 | 'info_dict': { | |
19 | 'id': '11595', | |
20 | 'title': 're:^奔跑吧兄弟', | |
21 | 'description': 'md5:1bf88bad6d850930f542d51547c089b8', | |
22 | }, | |
957e0db1 | 23 | 'playlist_mincount': 12, |
21f63302 YCH |
24 | }] |
25 | ||
03116772 YCH |
26 | def _call_api(self, path, category, playlist_id, note): |
27 | return self._download_json('http://app.video.baidu.com/%s/?worktype=adnative%s&id=%s' % ( | |
28 | path, category, playlist_id), playlist_id, note) | |
957e0db1 | 29 | |
21f63302 | 30 | def _real_extract(self, url): |
5ad28e7f | 31 | category, playlist_id = self._match_valid_url(url).groups() |
21f63302 | 32 | if category == 'show': |
957e0db1 | 33 | category = 'tvshow' |
34 | if category == 'tv': | |
35 | category = 'tvplay' | |
21f63302 | 36 | |
03116772 YCH |
37 | playlist_detail = self._call_api( |
38 | 'xqinfo', category, playlist_id, 'Download playlist JSON metadata') | |
21f63302 | 39 | |
957e0db1 | 40 | playlist_title = playlist_detail['title'] |
a1d9f6c5 | 41 | playlist_description = unescapeHTML(playlist_detail.get('intro')) |
21f63302 | 42 | |
03116772 YCH |
43 | episodes_detail = self._call_api( |
44 | 'xqsingle', category, playlist_id, 'Download episodes JSON metadata') | |
21f63302 | 45 | |
b7546397 YCH |
46 | entries = [self.url_result( |
47 | episode['url'], video_title=episode['title'] | |
48 | ) for episode in episodes_detail['videos']] | |
21f63302 YCH |
49 | |
50 | return self.playlist_result( | |
51 | entries, playlist_id, playlist_title, playlist_description) |