2020-08-11 17:02:29 +08:00
|
|
|
|
<div align=center>
|
|
|
|
|
<img src="docs/.vuepress/public/logo.png" width="200" height="200">
|
|
|
|
|
|
2018-08-14 00:46:45 +08:00
|
|
|
|
# NoneBot
|
2018-07-01 20:37:48 +08:00
|
|
|
|
|
2018-12-27 20:23:45 +08:00
|
|
|
|
[data:image/s3,"s3://crabby-images/7ca95/7ca95debc82e06b45b8bb1767bfb41fd82df0593" alt="License"](LICENSE)
|
|
|
|
|
[data:image/s3,"s3://crabby-images/6c2fa/6c2fa07bb18fa55f579676fe9fe564a5627d9a2d" alt="PyPI"](https://pypi.python.org/pypi/nonebot)
|
2020-02-14 17:12:36 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/0a9bf/0a9bf0268f853b1dc47e2e4c99cf2fb6fbf5d1dc" alt="Python Version"
|
|
|
|
|
data:image/s3,"s3://crabby-images/68523/685234fbf248f15888b6256b1741fb1829be0811" alt="CQHTTP Version"
|
2019-01-02 12:45:05 +08:00
|
|
|
|
[data:image/s3,"s3://crabby-images/3d302/3d302887a9826a4143d2e90d2be98a859892a38a" alt="QQ 群"](https://jq.qq.com/?_wv=1027&k=5OFifDh)
|
2018-08-26 13:44:54 +08:00
|
|
|
|
[data:image/s3,"s3://crabby-images/67e22/67e2214bde9f4b6896dde6f0293f6c321dede24c" alt="Telegram"](https://t.me/cqhttp)
|
2018-12-24 12:41:08 +08:00
|
|
|
|
[data:image/s3,"s3://crabby-images/63922/63922af1741b4c5cd7a258cd435ffea4aa989b50" alt="QQ 版本发布群"](https://jq.qq.com/?_wv=1027&k=5Nl0zhE)
|
|
|
|
|
[data:image/s3,"s3://crabby-images/e2877/e2877922654630ea94a299e02d497ea929997c8c" alt="Telegram 版本发布频道"](https://t.me/cqhttp_release)
|
2018-07-22 22:29:08 +08:00
|
|
|
|
|
2020-08-11 17:02:29 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
2018-08-26 13:44:54 +08:00
|
|
|
|
## 简介
|
2018-07-01 20:37:48 +08:00
|
|
|
|
|
2020-06-30 12:10:57 +08:00
|
|
|
|
NoneBot 是一个基于 [酷 Q](https://cqp.cc/) 的 Python 异步 QQ 机器人框架,它会对 QQ 机器人收到的消息进行解析和处理,并以插件化的形式,分发给消息所对应的命令处理器和自然语言处理器,来完成具体的功能。
|
2018-07-01 20:37:48 +08:00
|
|
|
|
|
2018-08-26 13:44:54 +08:00
|
|
|
|
除了起到解析消息的作用,NoneBot 还为插件提供了大量实用的预设操作和权限控制机制,尤其对于命令处理器,它更是提供了完善且易用的会话机制和内部调用机制,以分别适应命令的连续交互和插件内部功能复用等需求。
|
|
|
|
|
|
2020-06-30 12:10:57 +08:00
|
|
|
|
NoneBot 在其底层与 酷 Q 交互的部分使用 [python-aiocqhttp](https://github.com/richardchien/python-aiocqhttp) 库,后者是 [CQHTTP 插件](https://cqhttp.cc/) 的一个 Python 异步 SDK,在 [Quart](https://pgjones.gitlab.io/quart/) 的基础上封装了与 CQHTTP 插件的网络交互。
|
2018-08-26 13:44:54 +08:00
|
|
|
|
|
2020-03-16 23:33:34 +08:00
|
|
|
|
得益于 Python 的 [asyncio](https://docs.python.org/3/library/asyncio.html) 机制,NoneBot 处理消息的吞吐量有了很大的保障,再配合 CQHTTP 插件可选的 WebSocket 通信方式(也是最建议的通信方式),NoneBot 的性能可以达到 HTTP 通信方式的两倍以上,相较于传统同步 I/O 的 HTTP 通信,更是有质的飞跃。
|
2018-08-26 13:44:54 +08:00
|
|
|
|
|
2020-03-16 23:33:34 +08:00
|
|
|
|
需要注意的是,NoneBot 仅支持 Python 3.7+ 及 CQHTTP 插件 v4.8+。
|
2018-08-26 13:44:54 +08:00
|
|
|
|
|
2018-12-19 18:23:27 +08:00
|
|
|
|
## 示意图
|
|
|
|
|
|
2020-03-16 20:36:58 +08:00
|
|
|
|
data:image/s3,"s3://crabby-images/b3223/b3223343b39971e799a7af55ad77c52561e2726b" alt=""
|
2018-12-19 18:23:27 +08:00
|
|
|
|
|
2018-08-26 13:44:54 +08:00
|
|
|
|
## 文档
|
|
|
|
|
|
2020-01-18 20:25:55 +08:00
|
|
|
|
文档目前「指南」和「API」部分已经完成,「进阶」部分尚未完成,你可以在 [这里](https://nonebot.cqp.moe/) 查看。
|
2018-08-26 13:44:54 +08:00
|
|
|
|
|
|
|
|
|
## 贡献
|
|
|
|
|
|
2018-12-27 20:23:45 +08:00
|
|
|
|
如果你在使用过程中发现任何问题,可以 [提交 issue](https://github.com/richardchien/nonebot/issues/new) 或自行 fork 修改后提交 pull request。
|
2018-08-26 13:44:54 +08:00
|
|
|
|
|
|
|
|
|
如果你要提交 pull request,请确保你的代码风格和项目已有的代码保持一致,遵循 [PEP 8](https://www.python.org/dev/peps/pep-0008/),变量命名清晰,有适当的注释。
|