2020-11-18 15:12:48 +08:00

6.5 KiB

contentSidebar sidebarDepth
true 0

NoneBot.matcher 模块

事件响应器

该模块实现事件响应器的创建与运行,并提供一些快捷方法来帮助用户更好的与机器人进行 对话 。

matchers

  • 类型

    Dict[int, List[Type[Matcher]]]

  • 说明

    用于存储当前所有的事件响应器

class Matcher

基类:object

事件响应器类

module

  • 类型

    Optional[str]

  • 说明

    事件响应器所在模块名称

type

  • 类型

    str

  • 说明

    事件响应器类型

rule

  • 类型

    Rule

  • 说明

    事件响应器匹配规则

permission

  • 类型

    Permission

  • 说明

    事件响应器触发权限

priority

  • 类型

    int

  • 说明

    事件响应器优先级

block

  • 类型

    bool

  • 说明

    事件响应器是否阻止事件传播

temp

  • 类型

    bool

  • 说明

    事件响应器是否为临时

expire_time

  • 类型

    Optional[datetime]

  • 说明

    事件响应器过期时间点

_default_state

  • 类型

    dict

  • 说明

    事件响应器默认状态

_default_parser

  • 类型

    Optional[ArgsParser]

  • 说明

    事件响应器默认参数解析函数

__init__()

实例化 Matcher 以便运行

handlers

  • 类型

    List[Handler]

  • 说明

    事件响应器拥有的事件处理函数列表

classmethod new(type_='', rule=None, permission=None, handlers=None, temp=False, priority=1, block=False, *, module=None, default_state=None, expire_time=None)

  • 说明

    创建一个新的事件响应器,并存储至 matchers

  • 参数

    • type_: str: 事件响应器类型,与 event.type 一致时触发,空字符串表示任意

    • rule: Optional[Rule]: 匹配规则

    • permission: Optional[Permission]: 权限

    • handlers: Optional[List[Handler]]: 事件处理函数列表

    • temp: bool: 是否为临时事件响应器,即触发一次后删除

    • priority: int: 响应优先级

    • block: bool: 是否阻止事件向更低优先级的响应器传播

    • module: Optional[str]: 事件响应器所在模块名称

    • default_state: Optional[dict]: 默认状态 state

    • 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: 上报事件

    • state: dict: 当前状态

  • 返回

    • bool: 是否满足匹配规则

classmethod args_parser(func)

  • 说明

    装饰一个函数来更改当前事件响应器的默认参数解析函数

  • 参数

    • func: ArgsParser: 参数解析函数

classmethod handle()

  • 说明

    装饰一个函数来向事件响应器直接添加一个处理函数

  • 参数

classmethod receive()

  • 说明

    装饰一个函数来指示 NoneBot 在接收用户新的一条消息后继续运行该函数

  • 参数

classmethod got(key, prompt=None, args_parser=None)

  • 说明

    装饰一个函数来指示 NoneBot 当要获取的 key 不存在时接收用户新的一条消息并经过 ArgsParser 处理后再运行该函数,如果 key 已存在则直接继续运行

  • 参数

    • key: str: 参数名

    • prompt: Optional[Union[str, Message, MessageSegment]]: 在参数不存在时向用户发送的消息

    • args_parser: Optional[ArgsParser]: 可选参数解析函数,空则使用默认解析函数

async classmethod send(message, **kwargs)

  • 说明

    发送一条消息给当前交互用户

  • 参数

    • message: Union[str, Message, MessageSegment]: 消息内容

    • **kwargs: 其他传递给 bot.send 的参数,请参考对应 adapter 的 bot 对象 api

async classmethod finish(message=None, **kwargs)

  • 说明

    发送一条消息给当前交互用户并结束当前事件响应器

  • 参数

    • message: Union[str, Message, MessageSegment]: 消息内容

    • **kwargs: 其他传递给 bot.send 的参数,请参考对应 adapter 的 bot 对象 api

async classmethod pause(prompt=None, **kwargs)

  • 说明

    发送一条消息给当前交互用户并暂停事件响应器,在接收用户新的一条消息后继续下一个处理函数

  • 参数

    • prompt: Union[str, Message, MessageSegment]: 消息内容

    • **kwargs: 其他传递给 bot.send 的参数,请参考对应 adapter 的 bot 对象 api

async classmethod reject(prompt=None, **kwargs)

  • 说明

    发送一条消息给当前交互用户并暂停事件响应器,在接收用户新的一条消息后重新运行当前处理函数

  • 参数

    • prompt: Union[str, Message, MessageSegment]: 消息内容

    • **kwargs: 其他传递给 bot.send 的参数,请参考对应 adapter 的 bot 对象 api

class MatcherGroup

基类:object

事件响应器组合,统一管理。用法同 Matcher

__init__(type_='', rule=None, permission=None, handlers=None, temp=False, priority=1, block=False, *, module=None, default_state=None, expire_time=None)

  • 说明

    创建一个事件响应器组合,参数为默认值,与 Matcher.new 一致

matchers

  • 类型

    List[Type[Matcher]]

  • 说明

    组内事件响应器列表

new(type_='', rule=None, permission=None, handlers=None, temp=False, priority=1, block=False, *, module=None, default_state=None, expire_time=None)

  • 说明

    在组中创建一个新的事件响应器,参数留空则使用组合默认值

:::danger 警告 如果使用 handlers 参数覆盖组合默认值则该事件响应器不会随组合一起添加新的事件处理函数 :::