mirror of
https://github.com/soimort/you-get.git
synced 2025-02-03 08:43:58 +03:00
[acfun] fix #776
This commit is contained in:
parent
9a9e706cb6
commit
65e00b58cd
@ -13,15 +13,10 @@ from .youku import youku_download_by_vid
|
|||||||
import json, re
|
import json, re
|
||||||
|
|
||||||
def get_srt_json(id):
|
def get_srt_json(id):
|
||||||
# url = 'http://comment.acfun.tv/%s.json' % id
|
url = 'http://danmu.aixifan.com/V2/%s' % id
|
||||||
url = 'http://static.comment.acfun.mm111.net/%s' %id
|
|
||||||
return get_html(url)
|
return get_html(url)
|
||||||
|
|
||||||
def get_srt_lock_json(id):
|
def acfun_download_by_vid(vid, title, output_dir='.', merge=True, info_only=False, **kwargs):
|
||||||
url = 'http://comment.acfun.tv/%s_lock.json' % id
|
|
||||||
return get_html(url)
|
|
||||||
|
|
||||||
def acfun_download_by_vid(vid, title=None, output_dir='.', merge=True, info_only=False, **kwargs):
|
|
||||||
info = json.loads(get_html('http://www.acfun.tv/video/getVideo.aspx?id=' + vid))
|
info = json.loads(get_html('http://www.acfun.tv/video/getVideo.aspx?id=' + vid))
|
||||||
sourceType = info['sourceType']
|
sourceType = info['sourceType']
|
||||||
if 'sourceId' in info: sourceId = info['sourceId']
|
if 'sourceId' in info: sourceId = info['sourceId']
|
||||||
@ -37,85 +32,30 @@ def acfun_download_by_vid(vid, title=None, output_dir='.', merge=True, info_only
|
|||||||
elif sourceType == 'letv':
|
elif sourceType == 'letv':
|
||||||
letvcloud_download_by_vu(sourceId, '2d8c027396', title, output_dir=output_dir, merge=merge, info_only=info_only)
|
letvcloud_download_by_vu(sourceId, '2d8c027396', title, output_dir=output_dir, merge=merge, info_only=info_only)
|
||||||
elif sourceType == 'zhuzhan':
|
elif sourceType == 'zhuzhan':
|
||||||
videoList = info['videoList']
|
a = 'http://api.aixifan.com/plays/%s/realSource' % vid
|
||||||
playUrl = videoList[-1]['playUrl']
|
s = json.loads(get_content(a, headers={'deviceType': '1'}))
|
||||||
mime, ext, size = url_info(playUrl)
|
urls = s['data']['files'][-1]['url']
|
||||||
print_info(site_info, title, mime, size)
|
size = urls_size(urls)
|
||||||
|
print_info(site_info, title, 'mp4', size)
|
||||||
if not info_only:
|
if not info_only:
|
||||||
download_urls([playUrl], title, ext, size, output_dir, merge=merge)
|
download_urls(urls, title, 'mp4', size,
|
||||||
|
output_dir=output_dir, merge=merge)
|
||||||
else:
|
else:
|
||||||
raise NotImplementedError(sourceType)
|
raise NotImplementedError(sourceType)
|
||||||
|
|
||||||
if not info_only:
|
if not info_only and not dry_run:
|
||||||
title = get_filename(title)
|
if not kwargs['caption']:
|
||||||
|
print('Skipping danmaku.')
|
||||||
|
return
|
||||||
try:
|
try:
|
||||||
|
title = get_filename(title)
|
||||||
print('Downloading %s ...\n' % (title + '.cmt.json'))
|
print('Downloading %s ...\n' % (title + '.cmt.json'))
|
||||||
cmt = get_srt_json(vid)
|
cmt = get_srt_json(vid)
|
||||||
with open(os.path.join(output_dir, title + '.cmt.json'), 'w') as x:
|
with open(os.path.join(output_dir, title + '.cmt.json'), 'w', encoding='utf-8') as x:
|
||||||
x.write(cmt)
|
x.write(cmt)
|
||||||
# print('Downloading %s ...\n' % (title + '.cmt_lock.json'))
|
|
||||||
# cmt = get_srt_lock_json(danmakuId)
|
|
||||||
# with open(os.path.join(output_dir, title + '.cmt_lock.json'), 'w') as x:
|
|
||||||
# x.write(cmt)
|
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# decompile from player swf
|
|
||||||
# protected static const VIDEO_PARSE_API:String = "http://jiexi.acfun.info/index.php?vid=";
|
|
||||||
# protected static var VIDEO_RATES_CODE:Array = ["C40","C30","C20","C10"];
|
|
||||||
# public static var VIDEO_RATES_STRING:Array = ["原画","超清","高清","流畅"];
|
|
||||||
# Sometimes may find C80 but size smaller than C30
|
|
||||||
|
|
||||||
|
|
||||||
#def acfun_download_by_vid(vid, title=None, output_dir='.', merge=True, info_only=False ,**kwargs):
|
|
||||||
###api example http://jiexi.acfun.info/index.php?vid=1122870
|
|
||||||
#info = json.loads(get_content("http://jiexi.acfun.info/index.php?vid={}".format(vid)))
|
|
||||||
#assert info["code"] == 200
|
|
||||||
#assert info["success"] == True
|
|
||||||
|
|
||||||
#support_types = sorted(info["result"].keys(),key= lambda i: int(i[1:]))
|
|
||||||
|
|
||||||
#stream_id = None
|
|
||||||
#if "stream_id" in kwargs and kwargs["stream_id"] in support_types:
|
|
||||||
#stream_id = kwargs["stream_id"]
|
|
||||||
#else:
|
|
||||||
#print("Current Video Supports:")
|
|
||||||
#for i in support_types:
|
|
||||||
#if info["result"][i]["totalbytes"] != 0:
|
|
||||||
#print("\t--format",i,"<URL>:",info["result"][i]["quality"],"size:","%.2f"% (info["result"][i]["totalbytes"] / 1024.0 /1024.0),"MB")
|
|
||||||
#else:
|
|
||||||
#print("\t--format",i,"<URL>:",info["result"][i]["quality"])
|
|
||||||
##because C80 is not the best
|
|
||||||
#if "C80" not in support_types:
|
|
||||||
#stream_id = support_types[-1]
|
|
||||||
#else:
|
|
||||||
#stream_id = support_types[-2]
|
|
||||||
|
|
||||||
#urls = [None] * len(info["result"][stream_id]["files"])
|
|
||||||
#for i in info["result"][stream_id]["files"]:
|
|
||||||
#urls[i["no"]] = i["url"]
|
|
||||||
#ext = info["result"][stream_id]["files"][0]["type"]
|
|
||||||
#size = 0
|
|
||||||
#for i in urls:
|
|
||||||
#_, _, tmp =url_info(i)
|
|
||||||
#size +=tmp
|
|
||||||
#print_info(site_info, title, ext, size)
|
|
||||||
#print("Format: ",stream_id)
|
|
||||||
#print()
|
|
||||||
|
|
||||||
#if not info_only:
|
|
||||||
#download_urls(urls, title, ext, size, output_dir = output_dir, merge = merge)
|
|
||||||
#title = get_filename(title)
|
|
||||||
#try:
|
|
||||||
#print('Downloading %s ...\n' % (title + '.cmt.json'))
|
|
||||||
#cmt = get_srt_json(vid)
|
|
||||||
#with open(os.path.join(output_dir, title + '.cmt.json'), 'w') as x:
|
|
||||||
#x.write(cmt)
|
|
||||||
#except:
|
|
||||||
#pass
|
|
||||||
|
|
||||||
def acfun_download(url, output_dir='.', merge=True, info_only=False, **kwargs):
|
def acfun_download(url, output_dir='.', merge=True, info_only=False, **kwargs):
|
||||||
assert re.match(r'http://[^\.]+.acfun.[^\.]+/\D/\D\D(\d+)', url)
|
assert re.match(r'http://[^\.]+.acfun.[^\.]+/\D/\D\D(\d+)', url)
|
||||||
html = get_html(url)
|
html = get_html(url)
|
||||||
@ -126,15 +66,14 @@ def acfun_download(url, output_dir='.', merge=True, info_only=False, **kwargs):
|
|||||||
assert title
|
assert title
|
||||||
|
|
||||||
videos = re.findall("data-vid=\"(\d+)\".*href=\"[^\"]+\".*title=\"([^\"]+)\"", html)
|
videos = re.findall("data-vid=\"(\d+)\".*href=\"[^\"]+\".*title=\"([^\"]+)\"", html)
|
||||||
if videos is not None:
|
for video in videos:
|
||||||
for video in videos:
|
p_vid = video[0]
|
||||||
p_vid = video[0]
|
p_title = title + " - " + video[1] if video[1] != '删除标签' else title
|
||||||
p_title = title + " - " + video[1] if video[1] != '删除标签' else title
|
acfun_download_by_vid(p_vid, p_title,
|
||||||
acfun_download_by_vid(p_vid, p_title, output_dir=output_dir, merge=merge, info_only=info_only ,**kwargs)
|
output_dir=output_dir,
|
||||||
else:
|
merge=merge,
|
||||||
# Useless - to be removed?
|
info_only=info_only,
|
||||||
id = r1(r"src=\"/newflvplayer/player.*id=(\d+)", html)
|
**kwargs)
|
||||||
sina_download_by_vid(id, title, output_dir=output_dir, merge=merge, info_only=info_only)
|
|
||||||
|
|
||||||
site_info = "AcFun.tv"
|
site_info = "AcFun.tv"
|
||||||
download = acfun_download
|
download = acfun_download
|
||||||
|
Loading…
Reference in New Issue
Block a user