音频 / 语音笔记 — 2026-01-17
功能介绍
- 媒体识别(音频):如果启用了音频理解(或自动检测),OpenClaw 会:
- 定位第一个音频附件(本地路径或 URL),如有需要则下载。
- 在发送到各模型条目前,强制执行
maxBytes限制。 - 按顺序运行首个可用的模型条目(提供商或 CLI)。
- 若失败或跳过(因大小/超时),则尝试下一个条目。
- 成功时,用
[Audio]块替换Body并设置{{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)
仅提供商(Mistral Voxtral)
回显转录文本到聊天(可选)
注意事项与限制
- 提供商认证遵从标准模型认证顺序(认证配置文件、环境变量、
models.providers.*.apiKey)。 - 使用
provider: "deepgram"时,Deepgram 会自动使用DEEPGRAM_API_KEY。 - Deepgram 设置详情见:Deepgram (音频转录)。
- Mistral 设置详情见:Mistral。
- 音频提供商可通过
tools.media.audio覆盖baseUrl、headers和providerOptions。 - 默认大小上限为 20MB(
tools.media.audio.maxBytes)。超大音频会跳过该模型,并尝试下一个条目。 - 小于 1024 字节的空/微小音频文件在提供商/CLI转录前被跳过。
- 音频的默认
maxChars未设置(转录全文)。可通过tools.media.audio.maxChars或单条目maxChars修剪输出。 - OpenAI 默认自动模型为
gpt-4o-mini-transcribe;可设为gpt-4o-transcribe以提高准确率。 - 使用
tools.media.audio.attachments可处理多条语音笔记(mode: "all"+maxAttachments)。 - 转录结果可通过模板变量
{{Transcript}}获取。 tools.media.audio.echoTranscript默认关闭,开启后会在代理处理前将转录文本回显给发起聊天。tools.media.audio.echoFormat定制回显文本(占位符:{transcript})。- CLI 标准输出被限制为 5MB,建议输出简洁明了。
代理环境支持
基于提供商的音频转录支持标准的外发代理环境变量:HTTPS_PROXYHTTP_PROXYhttps_proxyhttp_proxy
群组中的提及检测
当对群聊设置了requireMention: true,OpenClaw 会在检查提及之前先转录音频。这使得即使语音笔记中包含提及,也能顺利处理。
工作原理:
- 若语音消息无文本内容且群组要求提及,OpenClaw 会执行“预检”转录。
- 对转录结果检测提及模式(例如
@BotName、表情符号触发等)。 - 若检测到提及,消息走完整回复流程。
- 使用转录文本进行提及检测,使语音笔记能通过提及门槛。
- 预检转录失败时(超时、API 出错等),消息基于文本提及检测处理。
- 确保混合内容(文本+音频)不会被错误忽略。
- 设置
channels.telegram.groups.<chatId>.disableAudioPreflight: true可跳过该群的预检转录提及检测。 - 设置
channels.telegram.groups.<chatId>.topics.<threadId>.disableAudioPreflight可按话题覆盖(true跳过,false强制启用)。 - 默认值为
false(满足提及门条件时启用预检)。
requireMention: true,则语音笔记先被转录,检测到提及后,代理回复。
常见注意事项
- 范围规则遵循首次匹配优先。
chatType被规范化为direct,group,或room。 - 确保 CLI 退出码为 0 且输出纯文本;若输出 JSON,请用
jq -r .text提取。 - 对于
parakeet-mlx,若传入--output-dir,OpenClaw 会在--output-format为txt(或默认)时读取<output-dir>/<media-basename>.txt;非 txt 格式回退解析 stdout。 - 超时设置合理(
timeoutSeconds默认 60秒),避免阻塞回复队列。 - 预检转录只处理第一个音频附件用于提及检测,其他音频在主媒体识别阶段处理。