|
|
@ -9,13 +9,8 @@ from .common import InfoExtractor |
|
|
|
from ..utils import ( |
|
|
|
strip_jsonp, |
|
|
|
unescapeHTML, |
|
|
|
HEADRequest, |
|
|
|
ExtractorError, |
|
|
|
) |
|
|
|
from ..compat import ( |
|
|
|
compat_urllib_request, |
|
|
|
compat_HTTPError, |
|
|
|
) |
|
|
|
from ..compat import compat_urllib_request |
|
|
|
|
|
|
|
|
|
|
|
class QQMusicIE(InfoExtractor): |
|
|
@ -104,24 +99,15 @@ class QQMusicIE(InfoExtractor): |
|
|
|
|
|
|
|
formats = [] |
|
|
|
for format_id, details in self._FORMATS.items(): |
|
|
|
video_url = 'http://cc.stream.qqmusic.qq.com/%s%s.%s?vkey=%s&guid=%s&fromtag=0' \ |
|
|
|
% (details['prefix'], mid, details['ext'], vkey, guid) |
|
|
|
req = HEADRequest(video_url) |
|
|
|
try: |
|
|
|
res = self._request_webpage( |
|
|
|
req, mid, note='Testing %s video URL' % format_id, fatal=False) |
|
|
|
except ExtractorError as e: |
|
|
|
if isinstance(e.cause, compat_HTTPError) and e.cause.code in [400, 404]: |
|
|
|
self.report_warning('Invalid %s video URL' % format_id, mid) |
|
|
|
else: |
|
|
|
if res: |
|
|
|
formats.append({ |
|
|
|
'url': video_url, |
|
|
|
'format': format_id, |
|
|
|
'format_id': format_id, |
|
|
|
'preference': details['preference'], |
|
|
|
'abr': details.get('abr'), |
|
|
|
}) |
|
|
|
formats.append({ |
|
|
|
'url': 'http://cc.stream.qqmusic.qq.com/%s%s.%s?vkey=%s&guid=%s&fromtag=0' |
|
|
|
% (details['prefix'], mid, details['ext'], vkey, guid), |
|
|
|
'format': format_id, |
|
|
|
'format_id': format_id, |
|
|
|
'preference': details['preference'], |
|
|
|
'abr': details.get('abr'), |
|
|
|
}) |
|
|
|
self._check_formats(formats, mid) |
|
|
|
self._sort_formats(formats) |
|
|
|
|
|
|
|
return { |
|
|
|