音频 / 语音笔记 — 2026-01-17
功能现状
- 媒体理解 (音频): 如果启用了音频理解(或自动检测),OpenClaw 会:
- 定位第一个音频附件(本地路径或 URL)并在需要时下载。
- 在发送到每个模型条目之前强制执行
maxBytes。 - 按顺序运行第一个符合条件的模型条目(提供商或 CLI)。
- 如果失败或跳过(大小/超时),它会尝试下一个条目。
- 成功时,它将
Body替换为[Audio]块并设置{{Transcript}}。
- 命令解析: 当转录成功时,
CommandBody/RawBody设置为转录文本,以便斜杠命令仍然有效。 - 详细日志: 在
--verbose模式下,我们会记录转录何时运行以及何时替换正文。
自动检测 (默认)
如果你 没有配置模型 并且tools.media.audio.enabled 未 设置为 false,
OpenClaw 会按以下顺序自动检测并在第一个可用的选项处停止:
- 本地 CLI (如果已安装)
sherpa-onnx-offline(需要带有编码器/解码器/连接器/令牌的SHERPA_ONNX_MODEL_DIR)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 模型。
配置示例
提供商 + CLI 回退 (OpenAI + Whisper CLI)
仅提供商带范围控制
仅提供商 (Deepgram)
说明 & 限制
- 提供商认证遵循标准模型认证顺序(认证配置文件、环境变量、
models.providers.*.apiKey)。 - 当使用
provider: "deepgram"时,Deepgram 会获取DEEPGRAM_API_KEY。 - Deepgram 设置详情:Deepgram (音频转录)。
- 音频提供商可以通过
tools.media.audio覆盖baseUrl,headers和providerOptions。 - 默认大小上限为 20MB (
tools.media.audio.maxBytes)。超大音频将跳过该模型并尝试下一个条目。 - 音频的默认
maxChars未设置(完整转录)。设置tools.media.audio.maxChars或每个条目的maxChars以修剪输出。 - OpenAI 自动默认值为
gpt-4o-mini-transcribe;设置model: "gpt-4o-transcribe"以获得更高准确性。 - 使用
tools.media.audio.attachments处理多个语音笔记 (mode: "all"+maxAttachments)。 - 转录可通过
{{Transcript}}在模板中使用。 - CLI stdout 有上限 (5MB);保持 CLI 输出简洁。
常见问题
- 范围规则使用首次匹配获胜。
chatType标准化为direct,group, 或room。 - 确保你的 CLI 退出码为 0 并打印纯文本;JSON 需要通过
jq -r .text处理。 - 保持合理的超时时间 (
timeoutSeconds, 默认 60s) 以避免阻塞回复队列。