1
0
mirror of https://github.com/l1ving/youtube-dl synced 2024-11-25 16:45:36 +08:00
youtube-dl/youtube_dl/extractor/vine.py

41 lines
1.2 KiB
Python
Raw Normal View History

2013-06-24 04:26:30 +08:00
import re
from .common import InfoExtractor
class VineIE(InfoExtractor):
_VALID_URL = r'(?:https?://)?(?:www\.)?vine\.co/v/(?P<id>\w+)'
2013-06-28 02:46:46 +08:00
_TEST = {
u'url': u'https://vine.co/v/b9KOOWX7HUx',
u'file': u'b9KOOWX7HUx.mp4',
u'md5': u'2f36fed6235b16da96ce9b4dc890940d',
u'info_dict': {
u"uploader": u"Jack Dorsey",
u"title": u"Chicken."
}
}
2013-06-24 04:26:30 +08:00
def _real_extract(self, url):
mobj = re.match(self._VALID_URL, url)
video_id = mobj.group('id')
webpage_url = 'https://vine.co/v/' + video_id
webpage = self._download_webpage(webpage_url, video_id)
self.report_extraction(video_id)
video_url = self._html_search_regex(r'<meta property="twitter:player:stream" content="(.+?)"',
webpage, u'video URL')
2013-11-13 03:50:52 +08:00
uploader = self._html_search_regex(r'<p class="username">(.*?)</p>',
2013-06-24 04:26:30 +08:00
webpage, u'uploader', fatal=False, flags=re.DOTALL)
return [{
'id': video_id,
'url': video_url,
'ext': 'mp4',
'title': self._og_search_title(webpage),
'thumbnail': self._og_search_thumbnail(webpage),
2013-06-24 04:26:30 +08:00
'uploader': uploader,
}]