2020-10-06 02:08:48 +08:00
|
|
|
---
|
|
|
|
contentSidebar: true
|
|
|
|
sidebarDepth: 0
|
|
|
|
---
|
|
|
|
|
|
|
|
# NoneBot.matcher 模块
|
|
|
|
|
|
|
|
## 事件响应器
|
|
|
|
|
2021-03-20 14:49:58 +08:00
|
|
|
该模块实现事件响应器的创建与运行,并提供一些快捷方法来帮助用户更好的与机器人进行对话 。
|
2020-10-06 02:08:48 +08:00
|
|
|
|
|
|
|
|
|
|
|
## `matchers`
|
|
|
|
|
|
|
|
|
|
|
|
* **类型**
|
|
|
|
|
|
|
|
`Dict[int, List[Type[Matcher]]]`
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
用于存储当前所有的事件响应器
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## _class_ `Matcher`
|
|
|
|
|
|
|
|
基类:`object`
|
|
|
|
|
|
|
|
事件响应器类
|
|
|
|
|
|
|
|
|
|
|
|
### `module`
|
|
|
|
|
|
|
|
|
|
|
|
* **类型**
|
|
|
|
|
2021-05-10 18:42:32 +08:00
|
|
|
`Optional[ModuleType]`
|
2020-10-06 02:08:48 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
2021-05-10 18:42:32 +08:00
|
|
|
事件响应器所在模块
|
2020-10-06 02:08:48 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
2021-05-12 04:03:04 +00:00
|
|
|
### `plugin_name`
|
|
|
|
|
|
|
|
|
|
|
|
* **类型**
|
|
|
|
|
|
|
|
`Optional[str]`
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
事件响应器所在插件名
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### `module_name`
|
|
|
|
|
|
|
|
|
|
|
|
* **类型**
|
|
|
|
|
|
|
|
`Optional[str]`
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
事件响应器所在模块名
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### `module_prefix`
|
|
|
|
|
|
|
|
|
|
|
|
* **类型**
|
|
|
|
|
|
|
|
`Optional[str]`
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
事件响应器所在模块前缀
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-10-06 02:08:48 +08:00
|
|
|
### `type`
|
|
|
|
|
|
|
|
|
|
|
|
* **类型**
|
|
|
|
|
|
|
|
`str`
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
事件响应器类型
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### `rule`
|
|
|
|
|
|
|
|
|
|
|
|
* **类型**
|
|
|
|
|
|
|
|
`Rule`
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
事件响应器匹配规则
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### `permission`
|
|
|
|
|
|
|
|
|
|
|
|
* **类型**
|
|
|
|
|
|
|
|
`Permission`
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
事件响应器触发权限
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### `priority`
|
|
|
|
|
|
|
|
|
|
|
|
* **类型**
|
|
|
|
|
|
|
|
`int`
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
事件响应器优先级
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### `block`
|
|
|
|
|
|
|
|
|
|
|
|
* **类型**
|
|
|
|
|
|
|
|
`bool`
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
事件响应器是否阻止事件传播
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### `temp`
|
|
|
|
|
|
|
|
|
|
|
|
* **类型**
|
|
|
|
|
|
|
|
`bool`
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
事件响应器是否为临时
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### `expire_time`
|
|
|
|
|
|
|
|
|
|
|
|
* **类型**
|
|
|
|
|
|
|
|
`Optional[datetime]`
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
事件响应器过期时间点
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### `_default_state`
|
|
|
|
|
|
|
|
|
|
|
|
* **类型**
|
|
|
|
|
2020-12-19 15:31:14 +08:00
|
|
|
`T_State`
|
2020-10-06 02:08:48 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
事件响应器默认状态
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-12-20 04:15:01 +00:00
|
|
|
### `_default_state_factory`
|
|
|
|
|
|
|
|
|
|
|
|
* **类型**
|
|
|
|
|
|
|
|
`Optional[T_State]`
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
事件响应器默认工厂函数
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-10-06 02:08:48 +08:00
|
|
|
### `_default_parser`
|
|
|
|
|
|
|
|
|
|
|
|
* **类型**
|
|
|
|
|
2020-12-19 15:31:14 +08:00
|
|
|
`Optional[T_ArgsParser]`
|
2020-10-06 02:08:48 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
事件响应器默认参数解析函数
|
|
|
|
|
|
|
|
|
|
|
|
|
2021-03-03 16:06:19 +08:00
|
|
|
### `_default_type_updater`
|
|
|
|
|
|
|
|
|
|
|
|
* **类型**
|
|
|
|
|
2021-03-20 14:49:58 +08:00
|
|
|
`Optional[T_TypeUpdater]`
|
2021-03-03 16:06:19 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
事件响应器类型更新函数
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### `_default_permission_updater`
|
|
|
|
|
|
|
|
|
|
|
|
* **类型**
|
|
|
|
|
2021-03-20 14:49:58 +08:00
|
|
|
`Optional[T_PermissionUpdater]`
|
2021-03-03 16:06:19 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
事件响应器权限更新函数
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-10-06 17:03:05 +08:00
|
|
|
### `__init__()`
|
|
|
|
|
|
|
|
实例化 Matcher 以便运行
|
|
|
|
|
|
|
|
|
2020-10-06 02:08:48 +08:00
|
|
|
### `handlers`
|
|
|
|
|
|
|
|
|
|
|
|
* **类型**
|
|
|
|
|
2021-03-20 14:49:58 +08:00
|
|
|
`List[Handler]`
|
2020-10-06 02:08:48 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
事件响应器拥有的事件处理函数列表
|
|
|
|
|
|
|
|
|
|
|
|
|
2021-05-30 11:07:27 +08:00
|
|
|
### _classmethod_ `new(type_='', rule=None, permission=None, handlers=None, temp=False, priority=1, block=False, *, module=None, expire_time=None, default_state=None, default_state_factory=None, default_parser=None, default_type_updater=None, default_permission_updater=None)`
|
2020-10-06 02:08:48 +08:00
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
创建一个新的事件响应器,并存储至 [matchers](#matchers)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **参数**
|
|
|
|
|
|
|
|
|
2020-12-31 17:58:09 +08:00
|
|
|
* `type_: str`: 事件响应器类型,与 `event.get_type()` 一致时触发,空字符串表示任意
|
2020-10-06 02:08:48 +08:00
|
|
|
|
|
|
|
|
|
|
|
* `rule: Optional[Rule]`: 匹配规则
|
|
|
|
|
|
|
|
|
|
|
|
* `permission: Optional[Permission]`: 权限
|
|
|
|
|
|
|
|
|
2020-12-19 15:31:14 +08:00
|
|
|
* `handlers: Optional[List[T_Handler]]`: 事件处理函数列表
|
2020-10-06 02:08:48 +08:00
|
|
|
|
|
|
|
|
|
|
|
* `temp: bool`: 是否为临时事件响应器,即触发一次后删除
|
|
|
|
|
|
|
|
|
|
|
|
* `priority: int`: 响应优先级
|
|
|
|
|
|
|
|
|
|
|
|
* `block: bool`: 是否阻止事件向更低优先级的响应器传播
|
|
|
|
|
|
|
|
|
|
|
|
* `module: Optional[str]`: 事件响应器所在模块名称
|
|
|
|
|
|
|
|
|
2020-12-19 15:31:14 +08:00
|
|
|
* `default_state: Optional[T_State]`: 默认状态 `state`
|
2020-10-06 02:08:48 +08:00
|
|
|
|
|
|
|
|
2020-12-20 04:15:01 +00:00
|
|
|
* `default_state_factory: Optional[T_StateFactory]`: 默认状态 `state` 的工厂函数
|
|
|
|
|
|
|
|
|
2020-10-06 02:08:48 +08:00
|
|
|
* `expire_time: Optional[datetime]`: 事件响应器最终有效时间点,过时即被删除
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **返回**
|
|
|
|
|
|
|
|
|
|
|
|
* `Type[Matcher]`: 新的事件响应器类
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### _async classmethod_ `check_perm(bot, event)`
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
检查是否满足触发权限
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **参数**
|
|
|
|
|
|
|
|
|
|
|
|
* `bot: Bot`: Bot 对象
|
|
|
|
|
|
|
|
|
|
|
|
* `event: Event`: 上报事件
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **返回**
|
|
|
|
|
|
|
|
|
|
|
|
* `bool`: 是否满足权限
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### _async classmethod_ `check_rule(bot, event, state)`
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
检查是否满足匹配规则
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **参数**
|
|
|
|
|
|
|
|
|
|
|
|
* `bot: Bot`: Bot 对象
|
|
|
|
|
|
|
|
|
|
|
|
* `event: Event`: 上报事件
|
|
|
|
|
|
|
|
|
2020-12-19 15:31:14 +08:00
|
|
|
* `state: T_State`: 当前状态
|
2020-10-06 02:08:48 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **返回**
|
|
|
|
|
|
|
|
|
|
|
|
* `bool`: 是否满足匹配规则
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### _classmethod_ `args_parser(func)`
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
2020-10-06 17:03:05 +08:00
|
|
|
装饰一个函数来更改当前事件响应器的默认参数解析函数
|
2020-10-06 02:08:48 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **参数**
|
|
|
|
|
|
|
|
|
2020-12-19 15:31:14 +08:00
|
|
|
* `func: T_ArgsParser`: 参数解析函数
|
2020-10-06 02:08:48 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
2021-03-03 16:06:19 +08:00
|
|
|
### _classmethod_ `type_updater(func)`
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
装饰一个函数来更改当前事件响应器的默认响应事件类型更新函数
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **参数**
|
|
|
|
|
|
|
|
|
|
|
|
* `func: T_TypeUpdater`: 响应事件类型更新函数
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### _classmethod_ `permission_updater(func)`
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
装饰一个函数来更改当前事件响应器的默认会话权限更新函数
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **参数**
|
|
|
|
|
|
|
|
|
|
|
|
* `func: T_PermissionUpdater`: 会话权限更新函数
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-10-06 02:08:48 +08:00
|
|
|
### _classmethod_ `handle()`
|
|
|
|
|
2020-10-06 17:03:05 +08:00
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
装饰一个函数来向事件响应器直接添加一个处理函数
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **参数**
|
|
|
|
|
|
|
|
|
|
|
|
* 无
|
|
|
|
|
2020-10-06 02:08:48 +08:00
|
|
|
|
|
|
|
|
|
|
|
### _classmethod_ `receive()`
|
|
|
|
|
2020-10-06 17:03:05 +08:00
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
装饰一个函数来指示 NoneBot 在接收用户新的一条消息后继续运行该函数
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **参数**
|
|
|
|
|
|
|
|
|
|
|
|
* 无
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### _classmethod_ `got(key, prompt=None, args_parser=None)`
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
装饰一个函数来指示 NoneBot 当要获取的 `key` 不存在时接收用户新的一条消息并经过 `ArgsParser` 处理后再运行该函数,如果 `key` 已存在则直接继续运行
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **参数**
|
|
|
|
|
|
|
|
|
|
|
|
* `key: str`: 参数名
|
|
|
|
|
|
|
|
|
|
|
|
* `prompt: Optional[Union[str, Message, MessageSegment]]`: 在参数不存在时向用户发送的消息
|
|
|
|
|
|
|
|
|
2020-12-19 15:31:14 +08:00
|
|
|
* `args_parser: Optional[T_ArgsParser]`: 可选参数解析函数,空则使用默认解析函数
|
2020-10-06 17:03:05 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
2020-10-18 15:04:45 +08:00
|
|
|
### _async classmethod_ `send(message, **kwargs)`
|
2020-10-06 17:03:05 +08:00
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
发送一条消息给当前交互用户
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **参数**
|
|
|
|
|
|
|
|
|
|
|
|
* `message: Union[str, Message, MessageSegment]`: 消息内容
|
|
|
|
|
|
|
|
|
2020-10-18 15:04:45 +08:00
|
|
|
* `**kwargs`: 其他传递给 `bot.send` 的参数,请参考对应 adapter 的 bot 对象 api
|
2020-10-06 17:03:05 +08:00
|
|
|
|
2020-10-18 15:04:45 +08:00
|
|
|
|
|
|
|
|
|
|
|
### _async classmethod_ `finish(message=None, **kwargs)`
|
2020-10-06 17:03:05 +08:00
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
发送一条消息给当前交互用户并结束当前事件响应器
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **参数**
|
|
|
|
|
|
|
|
|
|
|
|
* `message: Union[str, Message, MessageSegment]`: 消息内容
|
|
|
|
|
|
|
|
|
2020-10-18 15:04:45 +08:00
|
|
|
* `**kwargs`: 其他传递给 `bot.send` 的参数,请参考对应 adapter 的 bot 对象 api
|
|
|
|
|
|
|
|
|
2020-10-06 17:03:05 +08:00
|
|
|
|
2020-10-18 15:04:45 +08:00
|
|
|
### _async classmethod_ `pause(prompt=None, **kwargs)`
|
2020-10-06 17:03:05 +08:00
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
发送一条消息给当前交互用户并暂停事件响应器,在接收用户新的一条消息后继续下一个处理函数
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **参数**
|
|
|
|
|
|
|
|
|
|
|
|
* `prompt: Union[str, Message, MessageSegment]`: 消息内容
|
|
|
|
|
|
|
|
|
2020-10-18 15:04:45 +08:00
|
|
|
* `**kwargs`: 其他传递给 `bot.send` 的参数,请参考对应 adapter 的 bot 对象 api
|
2020-10-06 17:03:05 +08:00
|
|
|
|
2020-10-18 15:04:45 +08:00
|
|
|
|
|
|
|
|
|
|
|
### _async classmethod_ `reject(prompt=None, **kwargs)`
|
2020-10-06 17:03:05 +08:00
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
发送一条消息给当前交互用户并暂停事件响应器,在接收用户新的一条消息后重新运行当前处理函数
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
* **参数**
|
|
|
|
|
|
|
|
|
|
|
|
* `prompt: Union[str, Message, MessageSegment]`: 消息内容
|
|
|
|
|
|
|
|
|
2020-10-18 15:04:45 +08:00
|
|
|
* `**kwargs`: 其他传递给 `bot.send` 的参数,请参考对应 adapter 的 bot 对象 api
|
2021-02-26 17:00:38 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### `stop_propagation()`
|
|
|
|
|
|
|
|
|
|
|
|
* **说明**
|
|
|
|
|
|
|
|
阻止事件传播
|