2021-02-02 14:36:51 +08:00
|
|
|
|
# 概览
|
|
|
|
|
|
|
|
|
|
<!-- :::tip 提示
|
|
|
|
|
如果在阅读本文档时遇到难以理解的词汇,请随时查阅 [术语表](../glossary.md) 或使用 [Google 搜索](https://www.google.com/)。
|
|
|
|
|
::: -->
|
|
|
|
|
|
|
|
|
|
:::tip 提示
|
|
|
|
|
初次使用时可能会觉得这里的概览过于枯燥,可以先简单略读之后直接前往 [安装](./installation.md) 查看安装方法,并进行后续的基础使用教程。
|
|
|
|
|
:::
|
|
|
|
|
|
|
|
|
|
NoneBot2 是一个可扩展的 Python 异步机器人框架,它会对机器人收到的事件进行解析和处理,并以插件化的形式,按优先级分发给事件所对应的事件响应器,来完成具体的功能。
|
|
|
|
|
|
|
|
|
|
除了起到解析事件的作用,NoneBot 还为插件提供了大量实用的预设操作和权限控制机制。对于命令处理,它更是提供了完善且易用的会话机制和内部调用机制,以分别适应命令的连续交互和插件内部功能复用等需求。
|
|
|
|
|
|
|
|
|
|
得益于 Python 的 [asyncio](https://docs.python.org/3/library/asyncio.html) 机制,NoneBot 处理事件的吞吐量有了很大的保障,再配合 WebSocket 通信方式(也是最建议的通信方式),NoneBot 的性能可以达到 HTTP 通信方式的两倍以上,相较于传统同步 I/O 的 HTTP 通信,更是有质的飞跃。
|
|
|
|
|
|
2021-10-02 17:35:10 +08:00
|
|
|
|
需要注意的是,NoneBot 仅支持 **Python 3.7.3 以上版本**
|
2021-02-02 14:36:51 +08:00
|
|
|
|
|
|
|
|
|
## 特色
|
|
|
|
|
|
|
|
|
|
NoneBot2 的驱动框架 `Driver` 以及通信协议 `Adapter` 均可**自定义**,并且可以作为插件进行**替换/添加**!
|
|
|
|
|
|
|
|
|
|
- 提供使用简易的脚手架
|
|
|
|
|
- 提供丰富的官方插件
|
|
|
|
|
- 提供可添加/替换的驱动以及协议选项
|
|
|
|
|
- 基于异步 I/O
|
|
|
|
|
- 同时支持 HTTP 和反向 WebSocket 通信方式
|
|
|
|
|
- 支持多个机器人账号负载均衡
|
|
|
|
|
- 提供直观的交互式会话接口
|
|
|
|
|
- 提供可自定义的权限控制机制
|
|
|
|
|
- 多种方式渲染要发送的消息内容,使对话足够自然
|