跳转到内容

音频和语音笔记

  • 媒体理解(音频):如果启用了音频理解(或自动检测),OpenClaw 将执行以下操作:
    1. 定位第一个音频附件(本地路径或 URL),并在需要时下载它。
    2. 在发送到每个模型条目之前,强制执行 maxBytes
    3. 按顺序运行第一个符合条件的模型条目(提供商或 CLI)。
    4. 如果失败或跳过(由于大小/超时),它将尝试下一个条目。
    5. 成功后,它会将 Body 替换为 [Audio] 代码块,并设置 {{Transcript}}
  • 命令解析:转录成功后,CommandBody/RawBody 将被设置为转录文本,以便斜杠命令仍然可以正常工作。
  • 详细日志记录:在 --verbose 中,我们会记录转录运行的时间以及它替换正文的时间。

如果您未配置模型tools.media.audio.enabled 设置为 false, OpenClaw 将按以下顺序自动检测,并在找到第一个可用选项时停止:

  1. 当前回复模型,当其提供商支持音频理解时。
  2. 本地 CLI(如果已安装)
    • sherpa-onnx-offline(需要带有编码器/解码器/连接器/标记的 SHERPA_ONNX_MODEL_DIR
    • whisper-cli(来自 whisper-cpp;使用 WHISPER_CPP_MODEL 或捆绑的微型模型)
    • whisper(Python CLI;自动下载模型)
  3. Gemini CLIgemini)使用 read_many_files
  4. 提供商认证
    • 首先尝试支持音频的已配置 models.providers.* 条目
    • 捆绑的回退顺序:OpenAI → Groq → xAI → Deepgram → Google → SenseAudio → ElevenLabs → Mistral

要禁用自动检测,请设置 tools.media.audio.enabled: false。 要进行自定义,请设置 tools.media.audio.models。 注意:二进制检测在 macOS/Linux/Windows 上是尽力而为的;确保 CLI 位于 PATH 上(我们会展开 ~),或者使用完整命令路径设置显式的 CLI 模型。

提供商 + CLI 回退 (OpenAI + Whisper CLI)

Section titled “提供商 + CLI 回退 (OpenAI + Whisper CLI)”
{
tools: {
media: {
audio: {
enabled: true,
maxBytes: 20971520,
models: [
{ provider: "openai", model: "gpt-4o-mini-transcribe" },
{
type: "cli",
command: "whisper",
args: ["--model", "base", "{{MediaPath}}"],
timeoutSeconds: 45,
},
],
},
},
},
}
{
tools: {
media: {
audio: {
enabled: true,
scope: {
default: "allow",
rules: [{ action: "deny", match: { chatType: "group" } }],
},
models: [{ provider: "openai", model: "gpt-4o-mini-transcribe" }],
},
},
},
}
{
tools: {
media: {
audio: {
enabled: true,
models: [{ provider: "deepgram", model: "nova-3" }],
},
},
},
}
{
tools: {
media: {
audio: {
enabled: true,
models: [{ provider: "mistral", model: "voxtral-mini-latest" }],
},
},
},
}
{
tools: {
media: {
audio: {
enabled: true,
models: [{ provider: "senseaudio", model: "senseaudio-asr-pro-1.5-260319" }],
},
},
},
}

将转录回显到聊天(可选加入)

Section titled “将转录回显到聊天(可选加入)”
{
tools: {
media: {
audio: {
enabled: true,
echoTranscript: true, // default is false
echoFormat: '📝 "{transcript}"', // optional, supports {transcript}
models: [{ provider: "openai", model: "gpt-4o-mini-transcribe" }],
},
},
},
}
  • 提供商身份验证遵循标准模型身份验证顺序(身份验证配置文件、环境变量、models.providers.*.apiKey)。
  • Groq 设置详情:Groq
  • 当使用 provider: "deepgram" 时,Deepgram 会获取 DEEPGRAM_API_KEY
  • Deepgram 设置详情:Deepgram (音频转录)
  • Mistral 设置详情:Mistral
  • 当使用 provider: "senseaudio" 时,SenseAudio 会获取 SENSEAUDIO_API_KEY
  • SenseAudio 设置详情:SenseAudio
  • 音频提供商可以通过 tools.media.audio 覆盖 baseUrlheadersproviderOptions
  • 默认大小上限为 20MB (tools.media.audio.maxBytes)。对于该模型,将跳过超大的音频文件并尝试下一个条目。
  • 在提供商/CLI 转录之前,会跳过小于 1024 字节的微小/空音频文件。
  • 音频的默认 maxChars未设置(完整转录)。设置 tools.media.audio.maxChars 或每个条目的 maxChars 以裁剪输出。
  • OpenAI 自动默认值为 gpt-4o-mini-transcribe;设置 model: "gpt-4o-transcribe" 以获得更高的准确性。
  • 使用 tools.media.audio.attachments 处理多个语音笔记(mode: "all" + maxAttachments)。
  • 转录文本可作为 {{Transcript}} 供模板使用。
  • tools.media.audio.echoTranscript 默认处于关闭状态;启用它可以在代理处理之前将转录确认发送回原始聊天。
  • tools.media.audio.echoFormat 可自定义回显文本(占位符:{transcript})。
  • CLI stdout 被限制为 5MB;请保持 CLI 输出简洁。
  • CLI CLIargs 应使用 {{MediaPath}} 来指定本地音频文件路径。运行 openclaw doctor --fix 以迁移较旧 audio.transcription.command 配置中已弃用的 {input} 占位符。

基于提供商的音频转录遵循标准出站代理环境变量:

  • HTTPS_PROXY
  • HTTP_PROXY
  • ALL_PROXY
  • https_proxy
  • http_proxy
  • all_proxy

如果未设置代理环境变量,则使用直接出口。如果代理配置格式错误,OpenClaw 会记录警告并回退到直接获取。

当为群组聊天设置了 requireMention: trueOpenClaw 时,OpenClaw 现在会在检查提及之前转录音频。这使得即使语音笔记包含提及,也能对其进行处理。

工作原理:

  1. 如果语音消息没有文本正文且群组需要提及,OpenClaw 会执行“预检”转录。
  2. 转录文本会检查提及模式(例如 @BotName、表情符号触发器)。
  3. 如果发现提及,该消息将通过完整的回复管道处理。
  4. 转录文本用于提及检测,以便语音笔记能够通过提及关卡。

回退行为:

  • 如果预检期间转录失败(超时、API 错误等),则基于仅文本的提及检测处理该消息。
  • 这可确保混合消息(文本 + 音频)绝不会被错误地丢弃。

按 Telegram 群组/主题选择退出:

  • 设置 channels.telegram.groups.<chatId>.disableAudioPreflight: true 以跳过针对该群组的预转录提及检查。
  • 设置 channels.telegram.groups.<chatId>.topics.<threadId>.disableAudioPreflight 以覆盖每个主题的设置(true 表示跳过,false 表示强制启用)。
  • 默认值为 false(当提及门控条件匹配时启用预检查)。

示例: 用户在设置了 requireMention: true 的 Telegram 群组中发送了一条语音消息,内容为“嘿 @Claude,天气怎么样?”。语音消息被转录,检测到提及,代理随后回复。

  • 作用域规则采用首匹配优先原则。chatType 会被标准化为 directgrouproom
  • 请确保您的 CLI 以退出码 0 退出并输出纯文本;JSON 需要通过 jq -r .text 进行处理。
  • 对于 parakeet-mlx,如果您传递 --output-dir,当 --output-formattxt(或省略)时,OpenClaw 会读取 <output-dir>/<media-basename>.txt;非 txt 的输出格式将回退到标准输出解析。
  • 保持合理的超时时间(timeoutSeconds,默认为 60 秒),以避免阻塞回复队列。
  • 预转录转录仅处理第一个音频附件以进行提及检测。额外的音频将在主媒体理解阶段处理。