diff options
| author | Yen Chi Hsuan <yan12125@gmail.com> | 2016-04-23 02:51:17 +0800 | 
|---|---|---|
| committer | Yen Chi Hsuan <yan12125@gmail.com> | 2016-04-23 02:54:09 +0800 | 
| commit | eb01e97e10a5c1eb096695fbfd91ff7f69a4aa9e (patch) | |
| tree | 56a41a84138b26de7ee249f39cd1ea8f22bdd13c /youtube_dl/extractor/youku.py | |
| parent | cb7d4d0efd8c58485e5269895e128b649d8c6c0c (diff) | |
[youku] Skip streams with channel_type=tail
Fixes #9275
These video segments look like ads and they don't appear in the web
player.
Diffstat (limited to 'youtube_dl/extractor/youku.py')
| -rw-r--r-- | youtube_dl/extractor/youku.py | 14 | 
1 files changed, 14 insertions, 0 deletions
| diff --git a/youtube_dl/extractor/youku.py b/youtube_dl/extractor/youku.py index fd7eb5a6d..349ce0941 100644 --- a/youtube_dl/extractor/youku.py +++ b/youtube_dl/extractor/youku.py @@ -64,6 +64,14 @@ class YoukuIE(InfoExtractor):          'params': {              '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): @@ -92,6 +100,8 @@ class YoukuIE(InfoExtractor):          fileid_dict = {}          for stream in data['stream']: +            if stream.get('channel_type') == 'tail': +                continue              format = stream.get('stream_type')              fileid = stream['stream_fileid']              fileid_dict[format] = fileid @@ -117,6 +127,8 @@ class YoukuIE(InfoExtractor):          # generate video_urls          video_urls_dict = {}          for stream in data['stream']: +            if stream.get('channel_type') == 'tail': +                continue              format = stream.get('stream_type')              video_urls = []              for dt in stream['segs']: @@ -253,6 +265,8 @@ class YoukuIE(InfoExtractor):              # which one has all          } for i in range(max(len(v.get('segs')) for v in data['stream']))]          for stream in data['stream']: +            if stream.get('channel_type') == 'tail': +                continue              fm = stream.get('stream_type')              video_urls = video_urls_dict[fm]              for video_url, seg, entry in zip(video_urls, stream['segs'], entries): | 
