[youku] Skip streams with channel_type=tail

Fixes #9275

These video segments look like ads and they don't appear in the web
player.
This commit is contained in:
Yen Chi Hsuan 2016-04-23 02:51:17 +08:00
parent cb7d4d0efd
commit eb01e97e10
No known key found for this signature in database
GPG Key ID: 3FDDD575826C5C30
1 changed files with 14 additions and 0 deletions

View File

@ -64,6 +64,14 @@ class YoukuIE(InfoExtractor):
'params': { 'params': {
'videopassword': '100600', 'videopassword': '100600',
}, },
}, {
# /play/get.json contains streams with "channel_type":"tail"
'url': 'http://v.youku.com/v_show/id_XOTUxMzg4NDMy.html',
'info_dict': {
'id': 'XOTUxMzg4NDMy',
'title': '我的世界☆明月庄主☆车震猎杀☆杀人艺术Minecraft',
},
'playlist_count': 6,
}] }]
def construct_video_urls(self, data): def construct_video_urls(self, data):
@ -92,6 +100,8 @@ class YoukuIE(InfoExtractor):
fileid_dict = {} fileid_dict = {}
for stream in data['stream']: for stream in data['stream']:
if stream.get('channel_type') == 'tail':
continue
format = stream.get('stream_type') format = stream.get('stream_type')
fileid = stream['stream_fileid'] fileid = stream['stream_fileid']
fileid_dict[format] = fileid fileid_dict[format] = fileid
@ -117,6 +127,8 @@ class YoukuIE(InfoExtractor):
# generate video_urls # generate video_urls
video_urls_dict = {} video_urls_dict = {}
for stream in data['stream']: for stream in data['stream']:
if stream.get('channel_type') == 'tail':
continue
format = stream.get('stream_type') format = stream.get('stream_type')
video_urls = [] video_urls = []
for dt in stream['segs']: for dt in stream['segs']:
@ -253,6 +265,8 @@ class YoukuIE(InfoExtractor):
# which one has all # which one has all
} for i in range(max(len(v.get('segs')) for v in data['stream']))] } for i in range(max(len(v.get('segs')) for v in data['stream']))]
for stream in data['stream']: for stream in data['stream']:
if stream.get('channel_type') == 'tail':
continue
fm = stream.get('stream_type') fm = stream.get('stream_type')
video_urls = video_urls_dict[fm] video_urls = video_urls_dict[fm]
for video_url, seg, entry in zip(video_urls, stream['segs'], entries): for video_url, seg, entry in zip(video_urls, stream['segs'], entries):