[vk] Added a new information extractor for pages that are a list of a user\'s videos on vk.com. It works in a same way to playlist style pages for the YT information extractors.
This commit is contained in:
parent
23ad44b57b
commit
469d4c8968
youtube_dl/extractor
|
@ -452,7 +452,10 @@ from .vine import (
|
||||||
VineUserIE,
|
VineUserIE,
|
||||||
)
|
)
|
||||||
from .viki import VikiIE
|
from .viki import VikiIE
|
||||||
from .vk import VKIE
|
from .vk import (
|
||||||
|
VKIE,
|
||||||
|
VKUserVideosIE,
|
||||||
|
)
|
||||||
from .vodlocker import VodlockerIE
|
from .vodlocker import VodlockerIE
|
||||||
from .vporn import VpornIE
|
from .vporn import VpornIE
|
||||||
from .vrt import VRTIE
|
from .vrt import VRTIE
|
||||||
|
|
|
@ -16,7 +16,7 @@ from ..utils import (
|
||||||
|
|
||||||
class VKIE(InfoExtractor):
|
class VKIE(InfoExtractor):
|
||||||
IE_NAME = 'vk.com'
|
IE_NAME = 'vk.com'
|
||||||
_VALID_URL = r'https?://(?:m\.)?vk\.com/(?:video_ext\.php\?.*?\boid=(?P<oid>-?\d+).*?\bid=(?P<id>\d+)|(?:.+?\?.*?z=)?video(?P<videoid>.*?)(?:\?|%2F|$))'
|
_VALID_URL = r'https?://(?:m\.)?vk\.com/(?:video_ext\.php\?.*?\boid=(?P<oid>-?\d+).*?\bid=(?P<id>\d+)|(?:.+?\?.*?z=)?video(?P<videoid>[^s].*?)(?:\?|%2F|$))'
|
||||||
_NETRC_MACHINE = 'vk'
|
_NETRC_MACHINE = 'vk'
|
||||||
|
|
||||||
_TESTS = [
|
_TESTS = [
|
||||||
|
@ -185,3 +185,38 @@ class VKIE(InfoExtractor):
|
||||||
'uploader': data.get('md_author'),
|
'uploader': data.get('md_author'),
|
||||||
'duration': data.get('duration')
|
'duration': data.get('duration')
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
class VKUserVideosIE(InfoExtractor):
|
||||||
|
IE_NAME = 'vk.com:user-videos'
|
||||||
|
IE_DESC = 'All of a user\'s videos'
|
||||||
|
_VALID_URL = r'https?://(?:m\.)?vk\.com/videos([0-9]+)'
|
||||||
|
_TEMPLATE_URL = 'https://vk.com/videos'
|
||||||
|
_TEST = {
|
||||||
|
'url': 'http://vk.com/videos205387401',
|
||||||
|
'playlist_mincount': 4,
|
||||||
|
}
|
||||||
|
|
||||||
|
def extract_videos_from_page(self, page):
|
||||||
|
ids_in_page = []
|
||||||
|
for mobj in re.finditer(r'href="/video([0-9_]+)"', page):
|
||||||
|
if mobj.group(1) not in ids_in_page:
|
||||||
|
ids_in_page.append(mobj.group(1))
|
||||||
|
return ids_in_page
|
||||||
|
|
||||||
|
def _real_extract(self, url):
|
||||||
|
# Extract page id
|
||||||
|
mobj = re.match(self._VALID_URL, url)
|
||||||
|
if mobj is None:
|
||||||
|
raise ExtractorError('Invalid URL: %s' % url)
|
||||||
|
|
||||||
|
# Download page and get video ids
|
||||||
|
page_id = mobj.group(1)
|
||||||
|
page = self._download_webpage(url, page_id)
|
||||||
|
video_ids = self.extract_videos_from_page(page)
|
||||||
|
|
||||||
|
self._downloader.to_screen('[vk] User videos %s: Found %i videos' % (page_id, len(video_ids)))
|
||||||
|
|
||||||
|
url_entries = [self.url_result('http://vk.com/video' + video_id, 'VK', video_id=video_id)
|
||||||
|
for video_id in video_ids]
|
||||||
|
return self.playlist_result(url_entries, page_id)
|
Loading…
Reference in New Issue