音频 / 语音消息 — 2026-01-17
11. 可用功能
- 媒体理解(音频):如果音频理解已启用(或自动检测),OpenClaw 会:
- 找到第一个音频附件(本地路径或 URL),如有需要则下载。
- 在发送给每个模型条目之前执行
maxBytes限制。 - 按顺序运行第一个符合条件的模型条目(提供商或 CLI)。
- 如果失败或跳过(大小/超时),则尝试下一个条目。
- 成功后,将
Body替换为[Audio]块并设置{{Transcript}}。
- 命令解析:转录成功时,
CommandBody/RawBody会设置为转录文本,因此斜杠命令仍然有效。 - 详细日志:在
--verbose模式下,我们会在转录运行和替换正文时记录日志。
自动检测(默认)
如果你未配置模型且tools.media.audio.enabled 未设置为 false,OpenClaw 会按以下顺序自动检测,并在找到第一个可用选项时停止:
- 本地 CLI(如已安装)
sherpa-onnx-offline(需要SHERPA_ONNX_MODEL_DIR包含 encoder/decoder/joiner/tokens)whisper-cli(来自whisper-cpp;使用WHISPER_CPP_MODEL或内置的 tiny 模型)whisper(Python CLI;自动下载模型)
- Gemini CLI(
gemini)使用read_many_files - 提供商密钥(OpenAI → Groq → Deepgram → Google)
tools.media.audio.enabled: false。
要自定义,请设置 tools.media.audio.models。
注意:二进制检测在 macOS/Linux/Windows 上采用尽力而为的方式;请确保 CLI 在 PATH 中(我们会展开 ~),或通过完整命令路径设置显式 CLI 模型。
29. 要进行自定义,请设置 tools.media.audio.models。
30. 注意:在 macOS/Linux/Windows 上的二进制检测为尽力而为;请确保 CLI 在 PATH 中(我们会展开 ~),或使用包含完整命令路径的显式 CLI 模型。
配置示例
提供商 + CLI 回退(OpenAI + Whisper CLI)
34. 仅提供方并带作用域控制
仅提供商(Deepgram)
注意事项与限制
- 提供商认证遵循标准的模型认证顺序(认证配置文件、环境变量、
models.providers.*.apiKey)。 - 当使用
provider: "deepgram"时,Deepgram 会读取DEEPGRAM_API_KEY。 - Deepgram 设置详情:Deepgram(音频转录)。
- 音频提供商可以通过
tools.media.audio覆盖baseUrl、headers和providerOptions。 -
- 默认大小上限为 20MB(
tools.media.audio.maxBytes)。 默认大小限制为 20MB(tools.media.audio.maxBytes)。超大音频会跳过该模型并尝试下一个条目。
- 默认大小上限为 20MB(
-
- 音频的默认
maxChars未设置(完整转录)。 音频的默认maxChars未设置(完整转录文本)。设置tools.media.audio.maxChars或每个条目的maxChars来裁剪输出。
- 音频的默认
- OpenAI 自动检测默认使用
gpt-4o-mini-transcribe;设置model: "gpt-4o-transcribe"可获得更高准确度。 - 使用
tools.media.audio.attachments处理多条语音消息(mode: "all"+maxAttachments)。 - 转录文本可在模板中通过
{{Transcript}}使用。 - CLI 标准输出有上限(5MB);请保持 CLI 输出简洁。
群组中的提及检测
当为群聊设置requireMention: true 时,OpenClaw 现在会在检查提及之前先转录音频。 这使得即使语音消息中包含提及,也能够被处理。
工作原理:
- 如果语音消息没有文本内容且群组要求提及,OpenClaw 会执行一次“预检”转录。
- 系统会检查转录文本中的提及模式(例如
@BotName、表情触发器)。 - 如果检测到提及,消息将进入完整的回复处理流程。
- 该转录文本用于提及检测,使语音消息能够通过提及门控。
- 如果在预检阶段转录失败(超时、API 错误等),则基于纯文本提及检测来处理消息。
- 这可确保混合消息(文本 + 音频)不会被错误丢弃。
requireMention: true 的 Telegram 群组中发送了一条语音消息,说“Hey @Claude, what’s the weather?”。 语音消息被转录,检测到提及,随后代理进行回复。
注意事项
-
- 作用域规则采用“先匹配者优先”。 作用域规则采用首次匹配优先。
chatType会被规范化为direct、group或room。
- 作用域规则采用“先匹配者优先”。 作用域规则采用首次匹配优先。
- 确保你的 CLI 以退出码 0 退出并输出纯文本;JSON 格式需要通过
jq -r .text进行转换。 - 保持合理的超时时间(
timeoutSeconds,默认 60 秒),以避免阻塞回复队列。 - 预检转录仅处理第一个音频附件以进行提及检测。 其他音频将在主要媒体理解阶段处理。