youtube-dl/youtube_dl/extractor/tasvideos.py

41 lines
1.1 KiB
Python
Raw Normal View History

2020-12-26 02:59:26 +09:00
from __future__ import unicode_literals
from .common import InfoExtractor
2020-12-28 10:10:07 +09:00
import re
2020-12-26 02:59:26 +09:00
class TASVideosIE(InfoExtractor):
2020-12-26 02:59:26 +09:00
_VALID_URL = r'http://tasvideos.org/(?P<id>\d+M)\.html'
_TEST = {
'url': 'http://tasvideos.org/4352M.html',
2020-12-30 11:28:35 +09:00
'md5': '8dced25a575e853cec5533a887a8dcfc',
2020-12-26 02:59:26 +09:00
'info_dict': {
'id': '4352M',
'ext': 'mkv',
'title': 'C64 L\'Abbaye des Morts',
}
}
def _real_extract(self, url):
video_id = self._match_id(url)
webpage = self._download_webpage(url, video_id)
2020-12-28 10:10:07 +09:00
video_urls = re.findall(
2020-12-26 06:41:11 +09:00
r'<a [^>]+(?P<URL>archive\.org\/download[^<]+\.(?:mkv|mp4|avi))[^<]+<\/a>',
2020-12-28 10:10:07 +09:00
webpage)
2020-12-26 02:59:26 +09:00
title = self._search_regex(
r'<span title="Movie[^"]+">(?P<TITLE>[^<]+)<\/span>', webpage,
'title')
2020-12-28 10:10:07 +09:00
formats = []
for url in video_urls:
format_entry = {'url': "http://www." + url}
formats.append(format_entry)
self._sort_formats(formats)
2020-12-26 02:59:26 +09:00
return {
'id': video_id,
'title': title,
2020-12-28 10:10:07 +09:00
'formats': formats,
2020-12-26 02:59:26 +09:00
}