Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
无聊人士张
you-get
提交
b347b1bb
Y
you-get
项目概览
无聊人士张
/
you-get
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
Y
you-get
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
未验证
提交
b347b1bb
编写于
3月 30, 2020
作者:
M
Mort Yao
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[bilibili] support h
上级
5c339cc6
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
26 addition
and
0 deletion
+26
-0
src/you_get/extractors/bilibili.py
src/you_get/extractors/bilibili.py
+26
-0
未找到文件。
src/you_get/extractors/bilibili.py
浏览文件 @
b347b1bb
...
...
@@ -28,6 +28,8 @@ class Bilibili(VideoExtractor):
'container'
:
'FLV'
,
'video_resolution'
:
'360p'
,
'desc'
:
'流畅 360P'
},
# 'quality': 15?
{
'id'
:
'mp4'
,
'quality'
:
0
},
{
'id'
:
'jpg'
,
'quality'
:
0
},
]
@
staticmethod
...
...
@@ -114,6 +116,10 @@ class Bilibili(VideoExtractor):
def
bilibili_vc_api
(
video_id
):
return
'https://api.vc.bilibili.com/clip/v1/video/detail?video_id=%s'
%
video_id
@
staticmethod
def
bilibili_h_api
(
doc_id
):
return
'https://api.vc.bilibili.com/link_draw/v1/doc/detail?doc_id=%s'
%
doc_id
@
staticmethod
def
url_size
(
url
,
faker
=
False
,
headers
=
{},
err_value
=
0
):
try
:
...
...
@@ -161,6 +167,8 @@ class Bilibili(VideoExtractor):
sort
=
'vc'
elif
re
.
match
(
r
'https?://(www\.)?bilibili\.com/video/(av(\d+)|(BV(\S+)))'
,
self
.
url
):
sort
=
'video'
elif
re
.
match
(
r
'https?://h\.?bilibili\.com/(\d+)'
,
self
.
url
):
sort
=
'h'
else
:
self
.
download_playlist_by_url
(
self
.
url
,
**
kwargs
)
return
...
...
@@ -426,6 +434,24 @@ class Bilibili(VideoExtractor):
self
.
streams
[
'mp4'
]
=
{
'container'
:
container
,
'size'
:
size
,
'src'
:
[
playurl
]}
# h images
elif
sort
==
'h'
:
m
=
re
.
match
(
r
'https?://h\.?bilibili\.com/(\d+)'
,
self
.
url
)
doc_id
=
m
.
group
(
1
)
api_url
=
self
.
bilibili_h_api
(
doc_id
)
api_content
=
get_content
(
api_url
,
headers
=
self
.
bilibili_headers
())
h_info
=
json
.
loads
(
api_content
)
urls
=
[]
for
pic
in
h_info
[
'data'
][
'item'
][
'pictures'
]:
img_src
=
pic
[
'img_src'
]
urls
.
append
(
img_src
)
size
=
urls_size
(
urls
)
self
.
title
=
doc_id
container
=
'jpg'
# enforce JPG container
self
.
streams
[
container
]
=
{
'container'
:
container
,
'size'
:
size
,
'src'
:
urls
}
def
prepare_by_cid
(
self
,
avid
,
cid
,
title
,
html_content
,
playinfo
,
playinfo_
,
url
):
#response for interaction video
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录