2 changed files with 92 additions and 0 deletions
Unified View
Diff Options
@ -0,0 +1,91 @@ |
|||||
|
# coding: utf-8 |
||||
|
from __future__ import unicode_literals |
||||
|
|
||||
|
import re |
||||
|
|
||||
|
from .common import InfoExtractor |
||||
|
from ..utils import ( |
||||
|
compat_urllib_parse, |
||||
|
compat_urllib_request, |
||||
|
parse_duration, |
||||
|
) |
||||
|
|
||||
|
|
||||
|
class ShareSixIE(InfoExtractor): |
||||
|
_VALID_URL = r'https?://(?:www\.)?sharesix\.com/(?:f/)?(?P<id>[0-9a-zA-Z]+)' |
||||
|
_TESTS = [ |
||||
|
{ |
||||
|
'url': 'http://sharesix.com/f/OXjQ7Y6', |
||||
|
'md5': '9e8e95d8823942815a7d7c773110cc93', |
||||
|
'info_dict': { |
||||
|
'id': 'OXjQ7Y6', |
||||
|
'ext': 'mp4', |
||||
|
'title': 'big_buck_bunny_480p_surround-fix.avi', |
||||
|
'duration': 596, |
||||
|
'width': 854, |
||||
|
'height': 480, |
||||
|
}, |
||||
|
}, |
||||
|
{ |
||||
|
'url': 'http://sharesix.com/lfrwoxp35zdd', |
||||
|
'md5': 'dd19f1435b7cec2d7912c64beeee8185', |
||||
|
'info_dict': { |
||||
|
'id': 'lfrwoxp35zdd', |
||||
|
'ext': 'flv', |
||||
|
'title': 'WhiteBoard___a_Mac_vs_PC_Parody_Cartoon.mp4.flv', |
||||
|
'duration': 65, |
||||
|
'width': 1280, |
||||
|
'height': 720, |
||||
|
}, |
||||
|
} |
||||
|
] |
||||
|
|
||||
|
def _real_extract(self, url): |
||||
|
mobj = re.match(self._VALID_URL, url) |
||||
|
video_id = mobj.group('id') |
||||
|
|
||||
|
fields = { |
||||
|
'method_free': 'Free' |
||||
|
} |
||||
|
post = compat_urllib_parse.urlencode(fields) |
||||
|
req = compat_urllib_request.Request(url, post) |
||||
|
req.add_header('Content-type', 'application/x-www-form-urlencoded') |
||||
|
|
||||
|
webpage = self._download_webpage(req, video_id, |
||||
|
'Downloading video page') |
||||
|
|
||||
|
video_url = self._search_regex( |
||||
|
r"var\slnk1\s=\s'([^']+)'", webpage, 'video URL') |
||||
|
title = self._html_search_regex( |
||||
|
r'(?s)<dt>Filename:</dt>.+?<dd>(.+?)</dd>', webpage, 'title') |
||||
|
duration = parse_duration( |
||||
|
self._search_regex( |
||||
|
r'(?s)<dt>Length:</dt>.+?<dd>(.+?)</dd>', |
||||
|
webpage, |
||||
|
'duration', |
||||
|
fatal=False |
||||
|
) |
||||
|
) |
||||
|
|
||||
|
m = re.search( |
||||
|
r'''(?xs)<dt>Width\sx\sHeight</dt>.+? |
||||
|
<dd>(?P<width>\d+)\sx\s(?P<height>\d+)</dd>''', |
||||
|
webpage |
||||
|
) |
||||
|
width = height = None |
||||
|
if m: |
||||
|
width, height = int(m.group('width')), int(m.group('height')) |
||||
|
|
||||
|
formats = [{ |
||||
|
'format_id': 'sd', |
||||
|
'url': video_url, |
||||
|
'width': width, |
||||
|
'height': height, |
||||
|
}] |
||||
|
|
||||
|
return { |
||||
|
'id': video_id, |
||||
|
'title': title, |
||||
|
'duration': duration, |
||||
|
'formats': formats, |
||||
|
} |
Write
Preview
Loading…
Cancel
Save