rogerxavier's picture
Upload 258 files
0aee47a verified

这是一个解析器

# 需要单独安装 fastapi 和 uvicorn

from bilibili_api.tools.parser import get_fastapi

import uvicorn

if __name__ == "__main__":
    uvicorn.run(get_fastapi(), host="0.0.0.0", port=9000)

以上代码可以用来开启一个 uvicorn 后端,配合同目录下 Card.vue 可实现一个简单的 bilibili 主播卡片。

card


起因

很久很久之前,我刚来到这个仓库,当时有个 Issue #31 他说:

这个包可以在脚手架里用吗,我在vue-cli开发模式下启动直接提示跨域

解决办法是在后端写请求,例如使用 fastapi + uvicorn 开一个后端,自己写接口。

开始我不懂啥意思,直到后来我也写了点 vue ,用到了 bilibili 的接口发现跨域,我就打算按照那个方法写后端。

但是一个个重新写接口名再找对应函数确实很累,所以我写了这个解析器


用法

这段代码我已经部署在阿里云的函数计算里了,域名:https://aliyun.nana7mi.link

from bilibili_api import user, sync

async def main():
    return await user.User(uid=2).get_user_info()

print(sync(main()))

上述代码现在只需要一个链接:https://aliyun.nana7mi.link/user.User(2).get_user_info() 就能实现。

属于是从接口来回接口去了。

类似的还有 https://aliyun.nana7mi.link/live.LiveRoom(21452505).get_room_info()


FAQ

Q1. 这个有什么用呢?

前端访问不跨域了。

Q2. 为什么要解析器,直接用 eval() 不好吗?

有安全隐患,用解析器这样一步一步调用比较安全。


进阶用法

使用网址 params 请求参数储存值。

https://aliyun.nana7mi.link/comment.get_comments(708326075350908930,type,1:int)?type=comment.CommentResourceType.DYNAMIC

这个变量是另一个需要被解析的文本,为什么不直接放在网址里呢?因为放前面会被当做字符串传进去。

同时为了不让所有参数都以字符串传入,还加了类型标注,在变量后使用类似 :int 的方式来强制转换,目前支持 :int :float :bool :parse

其中 :parse 较为特殊,它的作用是解析前面这个字符串,用前面这个网址举例

https://aliyun.nana7mi.link/comment.get_comments(708326075350908930,comment.CommentResourceType.DYNAMIC:parse,1:int)


再高级一点呢

使用 ?max_age=86400 参数设置为期 86400 秒的缓存。

在获取的字典结果后再使用 .key 的方式获得更精细数据,节省带宽,例如:

https://aliyun.nana7mi.link/user.User(2).get_user_info().face?max_age=86400

对于列表结果可以使用 .index 的方式获取列表中对应元素,例如:

https://aliyun.nana7mi.link/user.User(660303135).get_dynamics(0:int).cards.3.card