you-get/src/you_get/extractor/qq.py

50 lines
1.6 KiB
Python
Raw Normal View History

2012-12-01 19:14:04 +04:00
#!/usr/bin/env python
__all__ = ['qq_download']
from ..common import *
def qq_download_by_id(id, title = None, output_dir = '.', merge = True, info_only = False):
url = 'http://vsrc.store.qq.com/%s.flv' % id
2013-12-31 17:49:20 +04:00
2012-12-01 19:14:04 +04:00
_, _, size = url_info(url)
2013-12-31 17:49:20 +04:00
2012-12-01 19:14:04 +04:00
print_info(site_info, title, 'flv', size)
if not info_only:
download_urls([url], title, 'flv', size, output_dir = output_dir, merge = merge)
def qq_download(url, output_dir = '.', merge = True, info_only = False):
if re.match(r'http://v.qq.com/([^\?]+)\?vid', url):
aid = r1(r'(.*)\.html', url)
vid = r1(r'http://v.qq.com/[^\?]+\?vid=(\w+)', url)
2013-12-31 17:49:20 +04:00
url = 'http://sns.video.qq.com/tvideo/fcgi-bin/video?vid=%s' % vid
2013-03-08 01:56:28 +04:00
if re.match(r'http://y.qq.com/([^\?]+)\?vid', url):
vid = r1(r'http://y.qq.com/[^\?]+\?vid=(\w+)', url)
2013-12-31 17:49:20 +04:00
2013-03-09 02:26:39 +04:00
url = "http://v.qq.com/page/%s.html" % vid
2013-12-31 17:49:20 +04:00
2013-03-09 02:26:39 +04:00
r_url = r1(r'<meta http-equiv="refresh" content="0;url=([^"]*)', get_html(url))
if r_url:
aid = r1(r'(.*)\.html', r_url)
url = "%s/%s.html" % (aid, vid)
2013-12-31 17:49:20 +04:00
2013-04-23 15:05:11 +04:00
if re.match(r'http://static.video.qq.com/.*vid=', url):
vid = r1(r'http://static.video.qq.com/.*vid=(\w+)', url)
url = "http://v.qq.com/page/%s.html" % vid
2013-12-31 17:49:20 +04:00
2012-12-01 19:14:04 +04:00
html = get_html(url)
2013-12-31 17:49:20 +04:00
title = match1(html, r'<title>(.+?)</title>', r'title:"([^"]+)"')[0].strip()
2012-12-01 19:14:04 +04:00
assert title
title = unescape_html(title)
title = escape_file_path(title)
2013-12-31 17:49:20 +04:00
id = vid
2012-12-01 19:14:04 +04:00
qq_download_by_id(id, title, output_dir = output_dir, merge = merge, info_only = info_only)
2013-01-11 07:43:30 +04:00
site_info = "QQ.com"
2012-12-01 19:14:04 +04:00
download = qq_download
download_playlist = playlist_not_supported('qq')