nonebot2/website/versioned_docs/version-2.1.0/api/message.md
noneflow[bot] 1e8c2cfc9f 🔖 Release 2.1.0
2023-09-10 03:45:49 +00:00

118 lines
2.5 KiB
Markdown

---
sidebar_position: 2
description: nonebot.message 模块
---
# nonebot.message
本模块定义了事件处理主要流程。
NoneBot 内部处理并按优先级分发事件给所有事件响应器,提供了多个插槽以进行事件的预处理等。
## _def_ `event_preprocessor(func)` {#event-preprocessor}
- **说明**
事件预处理。
装饰一个函数,使它在每次接收到事件并分发给各响应器之前执行。
- **参数**
- `func` ([T_EventPreProcessor](typing.md#T-EventPreProcessor))
- **返回**
- [T_EventPreProcessor](typing.md#T-EventPreProcessor)
## _def_ `event_postprocessor(func)` {#event-postprocessor}
- **说明**
事件后处理。
装饰一个函数,使它在每次接收到事件并分发给各响应器之后执行。
- **参数**
- `func` ([T_EventPostProcessor](typing.md#T-EventPostProcessor))
- **返回**
- [T_EventPostProcessor](typing.md#T-EventPostProcessor)
## _def_ `run_preprocessor(func)` {#run-preprocessor}
- **说明**
运行预处理。
装饰一个函数,使它在每次事件响应器运行前执行。
- **参数**
- `func` ([T_RunPreProcessor](typing.md#T-RunPreProcessor))
- **返回**
- [T_RunPreProcessor](typing.md#T-RunPreProcessor)
## _def_ `run_postprocessor(func)` {#run-postprocessor}
- **说明**
运行后处理。
装饰一个函数,使它在每次事件响应器运行后执行。
- **参数**
- `func` ([T_RunPostProcessor](typing.md#T-RunPostProcessor))
- **返回**
- [T_RunPostProcessor](typing.md#T-RunPostProcessor)
## _async def_ `check_and_run_matcher(Matcher, bot, event, state, stack=None, dependency_cache=None)` {#check-and-run-matcher}
- **说明:** 检查并运行事件响应器。
- **参数**
- `Matcher` (type[[Matcher](matcher.md#Matcher)]): 事件响应器
- `bot` ([Bot](adapters/index.md#Bot)): Bot 对象
- `event` ([Event](adapters/index.md#Event)): Event 对象
- `state` ([T_State](typing.md#T-State)): 会话状态
- `stack` (AsyncExitStack | None): 异步上下文栈
- `dependency_cache` ([T_DependencyCache](typing.md#T-DependencyCache) | None): 依赖缓存
- **返回**
- None
## _async def_ `handle_event(bot, event)` {#handle-event}
- **说明:** 处理一个事件。调用该函数以实现分发事件。
- **参数**
- `bot` ([Bot](adapters/index.md#Bot)): Bot 对象
- `event` ([Event](adapters/index.md#Event)): Event 对象
- **返回**
- None
- **用法**
```python
import asyncio
asyncio.create_task(handle_event(bot, event))
```