首页龙虾技能列表 › Video Translate — 视频翻译与配音

Video Translate — 视频翻译与配音

v2.22.0

利用 HeyGen 将现有视频翻译和配音为多种语言。适用于视频翻译、配音、创建多语言版本、音频翻译等场景。

2· 685·5 当前·5 累计
by @michaelwang11394 (Michael Wang)·MIT-0
下载技能包
License
MIT-0
最后更新
2026/4/6
安全扫描
VirusTotal
无害
查看报告
OpenClaw
安全
high confidence
该技能内部一致,仅记录如何调用 HeyGen 的视频翻译端点,仅请求 HeyGen API 密钥,无安装步骤或隐藏代码,行为如描述。
评估建议
该技能仅包装 HeyGen 的视频翻译 API,需要 HEYGEN_API_KEY。安装前确认信任 HeyGen,并舒适于将视频内容发送给该服务。避免提供高度敏感视频。若可能,限制 API 密钥权限,并在停止使用时旋转/撤销。谨慎提供 callback_url 值(将接收通知和可能的翻译视频链接)。由于技能为指令仅,无安装,具有小的本地足迹,但使用时会将数据发送给 HeyGen。...
详细分析 ▾
用途与能力
名称/描述(通过 HeyGen 的视频翻译)与声明的要求(HEYGEN_API_KEY)和 SKILL.md 示例(对 api.heygen.com 的 curl/TypeScript/Python)一致。未请求无关的凭证或二进制文件。
指令范围
运行时指令保持在主题上(POST /v2/video_translate、轮询、下载)。重要的隐私注意事项:使用该技能上传或引用用户视频内容到第三方(HeyGen),以及可选的 callback_url/webhook 支持,意味着完成通知可以发送到外部端点——这被预期但值得注意。
安装机制
无安装规格和代码文件——仅指令技能。技能本身不会下载或写入磁盘。
凭证需求
仅要求 HEYGEN_API_KEY 并声明为主要凭证,与联系 HeyGen 的 API 成比例。未请求其他秘密或配置路径。
持久化与权限
always 为 false,无安装或自修改行为。技能不请求永久系统存在或访问其他技能的配置。
安全有层次,运行前请审查代码。

License

MIT-0

可自由使用、修改和再分发,无需署名。

运行时依赖

无特殊依赖

版本

latestv2.22.02026/3/4

自动发布自提交 ce047e148b0ae2d2b598d79d38ee6712cb4a6a67

● 无害

安装命令 点击复制

官方npx clawhub@latest install video-translate
镜像加速npx clawhub@latest install video-translate --registry https://cn.clawhub-mirror.com

技能文档

将现有视频翻译并配音成多种语言,保留唇形同步和自然语音模式。提供视频 URL 或 HeyGen 视频 ID — 无需先在 HeyGen 上创建视频。

认证

所有请求都需要 X-Api-Key 请求头。设置 HEYGEN_API_KEY 环境变量。

curl -X POST "https://api.heygen.com/v2/video_translate" \
  -H "X-Api-Key: $HEYGEN_API_KEY" \
  -H "Content-Type: application/json" \
  -d '{"video_url": "https://example.com/video.mp4", "output_language": "es-ES"}'

默认工作流

  • 提供视频 URL 或 HeyGen 视频 ID
  • 使用目标语言调用 POST /v2/video_translate
  • 轮询 GET /v2/video_translate/{translate_id} 直到状态为 completed
  • 从返回的 URL 下载翻译后的视频

创建翻译任务

请求字段

字段类型必填描述
video_urlstringY要翻译的视频 URL(或 video_id
video_idstringYHeyGen 视频 ID(或 video_url
output_languagestringY目标语言代码(例如 "es-ES"
titlestring翻译后视频的名称
translate_audio_onlyboolean仅音频,无唇形同步(更快)
speaker_numnumber视频中的说话者数量
callback_idstring用于 webhook 跟踪的自定义 ID
callback_urlstring完成通知的 URL
必须提供 video_url video_id

curl

curl -X POST "https://api.heygen.com/v2/video_translate" \
  -H "X-Api-Key: $HEYGEN_API_KEY" \
  -H "Content-Type: application/json" \
  -d '{
    "video_url": "https://example.com/original-video.mp4",
    "output_language": "es-ES",
    "title": "Spanish Version"
  }'

TypeScript

interface VideoTranslateRequest {
  video_url?: string;
  video_id?: string;
  output_language: string;
  title?: string;
  translate_audio_only?: boolean;
  speaker_num?: number;
  callback_id?: string;
  callback_url?: string;
}

interface VideoTranslateResponse { error: null | string; data: { video_translate_id: string; }; }

async function translateVideo(config: VideoTranslateRequest): Promise { const response = await fetch("https://api.heygen.com/v2/video_translate", { method: "POST", headers: { "X-Api-Key": process.env.HEYGEN_API_KEY!, "Content-Type": "application/json", }, body: JSON.stringify(config), });

const json: VideoTranslateResponse = await response.json();

if (json.error) { throw new Error(json.error); }

return json.data.video_translate_id; }

Python

import requests
import os

def translate_video(config: dict) -> str: response = requests.post( "https://api.heygen.com/v2/video_translate", headers={ "X-Api-Key": os.environ["HEYGEN_API_KEY"], "Content-Type": "application/json" }, json=config )

data = response.json() if data.get("error"): raise Exception(data["error"])

return data["data"]["video_translate_id"]

支持的语言

语言代码备注
English (US)en-US默认源语言
Spanish (Spain)es-ES欧洲西班牙语
Spanish (Mexico)es-MX拉丁美洲西班牙语
Frenchfr-FR标准法语
Germande-DE标准德语
Italianit-IT标准意大利语
Portuguese (Brazil)pt-BR巴西葡萄牙语
Japaneseja-JP标准日语
Koreanko-KR标准韩语
Chinese (Mandarin)zh-CN简体中文
Hindihi-IN标准印地语
Arabicar-SA现代标准阿拉伯语

翻译选项

基础翻译(带唇形同步)

const config = {
  video_url: "https://example.com/original.mp4",
  output_language: "es-ES",
  title: "Spanish Translation",
};

仅音频翻译(更快,无唇形同步)

const config = {
  video_url: "https://example.com/original.mp4",
  output_language: "es-ES",
  translate_audio_only: true,
};

多说话者视频

const config = {
  video_url: "https://example.com/interview.mp4",
  output_language: "fr-FR",
  speaker_num: 2,
};

高级选项(v4 API)

如需更多翻译控制:

interface VideoTranslateV4Request {
  input_video_id?: string;
  google_url?: string;
  output_languages: string[];        // 一次调用支持多种语言
  name: string;
  srt_key?: string;                  // 自定义 SRT 字幕
  instruction?: string;
  vocabulary?: string[];             // 保留原样的术语
  brand_voice_id?: string;
  speaker_num?: number;
  keep_the_same_format?: boolean;
  input_language?: string;
  enable_video_stretching?: boolean;
  disable_music_track?: boolean;
  enable_speech_enhancement?: boolean;
  srt_role?: "input" | "output";
  translate_audio_only?: boolean;
}

多种输出语言

const config = {
  input_video_id: "original_video_id",
  output_languages: ["es-ES", "fr-FR", "de-DE"],
  name: "Multi-language translations",
};

自定义词汇表(保留特定术语)

const config = {
  video_url: "https://example.com/product-demo.mp4",
  output_language: "ja-JP",
  vocabulary: ["SuperWidget", "Pro Max", "TechCorp"],
};

自定义 SRT 字幕

const config = {
  video_url: "https://example.com/video.mp4",
  output_language: "es-ES",
  srt_key: "path/to/custom-subtitles.srt",
  srt_role: "input",
};

检查翻译状态

curl

curl -X GET "https://api.heygen.com/v2/video_translate/{translate_id}" \
  -H "X-Api-Key: $HEYGEN_API_KEY"

TypeScript

interface TranslateStatusResponse {
  error: null | string;
  data: {
    id: string;
    status: "pending" | "processing" | "completed" | "failed";
    video_url?: string;
    message?: string;
  };
}

async function getTranslateStatus(translateId: string): Promise { const response = await fetch( https://api.heygen.com/v2/video_translate/${translateId}, { headers: { "X-Api-Key": process.env.HEYGEN_API_KEY! } } );

const json: TranslateStatusResponse = await response.json();

if (json.error) { throw new Error(json.error); }

return json.data; }

轮询完成状态

翻译比标准视频生成本身更长 — 允许最长 30 分钟。

async function waitForTranslation(
  translateId: string,
  maxWaitMs = 1800000,
  pollIntervalMs = 30000
): Promise {
  const startTime = Date.now();

while (Date.now() - startTime < maxWaitMs) { const status = await getTranslateStatus(translateId);

switch (status.status) { case "completed": return status.video_url!; case "failed": throw new Error(status.message || "Translation failed"); default: console.log(Status: ${status.status}...); await new Promise((r) => setTimeout(r, pollIntervalMs)); } }

throw new Error("Translation timed out"); }

完整工作流

async function translateAndDownload(
  videoUrl: string,
  targetLanguage: string
): Promise {
  console.log(Starting translation to ${targetLanguage}...);
  const translateId = await translateVideo({
    video_url: videoUrl,
    output_language: targetLanguage,
  });
  console.log(Translation ID: ${translateId});

console.log("Processing translation..."); const translatedVideoUrl = await waitForTranslation(translateId); console.log(Translation complete: ${translatedVideoUrl});

return translatedVideoUrl; }

const spanishVideo = await translateAndDownload( "https://example.com/my-video.mp4", "es-ES" );

批量翻译

并行翻译成多种语言:

async function translateToMultipleLanguages(
  sourceVideoUrl: string,
  targetLanguages: string[]
): Promise> {
  const results: Record = {};

const translatePromises = targetLanguages.map(async (lang) => { const translateId = await translateVideo({ video_url: sourceVideoUrl, output_language: lang, }); return { lang, translateId }; });

const translationJobs = await Promise.all(translatePromises);

for (const job of translationJobs) { try { const videoUrl = await waitForTranslation(job.translateId); results[job.lang] = videoUrl; } catch (error) { results[job.lang] = error: ${error.message}; } }

return results; }

const translations = await translateToMultipleLanguages( "https://example.com/original.mp4", ["es-ES", "fr-FR", "de-DE", "ja-JP"] );

功能特性

  • 唇形同步 — 自动调整说话者的嘴唇动作以匹配翻译后的音频
  • 语音克隆 — 翻译后的音频与原始说话者的语音特征匹配
  • 音乐轨道控制 — 可选择使用 disable_music_track: true 移除背景音乐
  • 语音增强 — 使用 enable_speech_enhancement: true 改善音频质量

最佳实践

  • 源质量很重要 — 使用高质量的源视频获得更好的效果
  • 清晰的音频 — 语音清晰的视频翻译效果更好
  • 单说话者 — 单说话者内容效果最佳
  • 适中的语速 — 非常快的语速可能影响质量
  • 先测试 — 在翻译长视频之前先用短视频尝试
  • 留出额外时间 — 翻译比视频生成耗时更长(最长 30 分钟)

错误处理

常见错误及处理方式:

async function safeTranslate(
  videoUrl: string,
  targetLanguage: string
): Promise<{ success: boolean; result?: string; error?: string }> {
  try {
    const url = await translateAndDownload(videoUrl, targetLanguage);
    return { success: true, result: url };
  } catch (error) {
    if (error.message.includes("quota")) {
      return { success: false, error: "Insufficient credits" };
    }
    if (error.message.includes("duration")) {
      return { success: false, error: "Video too long" };
    }
    if (error.message.includes("format")) {
      return { success: false, error: "Unsupported video format" };
    }
    return { success: false, error: error.message };
  }
}
数据来源:ClawHub ↗ · 中文优化:龙虾技能库
OpenClaw 技能定制 / 插件定制 / 私有工作流定制

免费技能或插件可能存在安全风险,如需更匹配、更安全的方案,建议联系付费定制

了解定制服务