Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
无聊人士张
you-get
提交
f1ab3f22
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 搜索 >>
未验证
提交
f1ab3f22
编写于
2月 19, 2019
作者:
M
Mort Yao
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[bilibili] support bangumi/media
上级
90d40dcd
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
22 addition
and
2 deletion
+22
-2
src/you_get/extractors/bilibili.py
src/you_get/extractors/bilibili.py
+22
-2
未找到文件。
src/you_get/extractors/bilibili.py
浏览文件 @
f1ab3f22
...
...
@@ -104,8 +104,8 @@ class Bilibili(VideoExtractor):
elif
re
.
match
(
r
'https?://(www\.)?bilibili\.com/video/av(\d+)'
,
self
.
url
):
sort
=
'video'
else
:
log
.
e
(
'[Error] Unsupported URL pattern.'
)
exit
(
1
)
self
.
download_playlist_by_url
(
self
.
url
,
**
kwargs
)
return
# regular av video
if
sort
==
'video'
:
...
...
@@ -341,8 +341,14 @@ class Bilibili(VideoExtractor):
sort
=
'bangumi'
elif
match1
(
html_content
,
r
'<meta property="og:url" content="(https://www.bilibili.com/bangumi/play/[^"]+)"'
):
sort
=
'bangumi'
elif
re
.
match
(
r
'https?://(www\.)?bilibili\.com/bangumi/media/md(\d+)'
,
self
.
url
)
or
\
re
.
match
(
r
'https?://bangumi\.bilibili\.com/anime/(\d+)'
,
self
.
url
):
sort
=
'bangumi_md'
elif
re
.
match
(
r
'https?://(www\.)?bilibili\.com/video/av(\d+)'
,
self
.
url
):
sort
=
'video'
else
:
log
.
e
(
'[Error] Unsupported URL pattern.'
)
exit
(
1
)
# regular av video
if
sort
==
'video'
:
...
...
@@ -357,10 +363,24 @@ class Bilibili(VideoExtractor):
elif
sort
==
'bangumi'
:
initial_state_text
=
match1
(
html_content
,
r
'__INITIAL_STATE__=(.*?);\(function\(\)'
)
# FIXME
initial_state
=
json
.
loads
(
initial_state_text
)
epn
,
i
=
len
(
initial_state
[
'epList'
]),
0
for
ep
in
initial_state
[
'epList'
]:
i
+=
1
;
log
.
w
(
'Extracting %s of %s videos ...'
%
(
i
,
epn
))
ep_id
=
ep
[
'id'
]
epurl
=
'https://www.bilibili.com/bangumi/play/ep%s/'
%
ep_id
self
.
__class__
().
download_by_url
(
epurl
,
**
kwargs
)
sys
.
stdout
.
flush
()
elif
sort
==
'bangumi_md'
:
initial_state_text
=
match1
(
html_content
,
r
'__INITIAL_STATE__=(.*?);\(function\(\)'
)
# FIXME
initial_state
=
json
.
loads
(
initial_state_text
)
epn
,
i
=
len
(
initial_state
[
'mediaInfo'
][
'episodes'
]),
0
for
ep
in
initial_state
[
'mediaInfo'
][
'episodes'
]:
i
+=
1
;
log
.
w
(
'Extracting %s of %s videos ...'
%
(
i
,
epn
))
ep_id
=
ep
[
'ep_id'
]
epurl
=
'https://www.bilibili.com/bangumi/play/ep%s/'
%
ep_id
self
.
__class__
().
download_by_url
(
epurl
,
**
kwargs
)
sys
.
stdout
.
flush
()
site
=
Bilibili
()
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录