Install
openclaw skills install byted-kickart-video-subtitler视频字幕添加SKILL:为视频文件自动添加、嵌入字幕。适用于给视频添加字幕、视频加字幕、视频打字幕、给视频生成字幕、字幕嵌入视频、视频配字幕等场景。触发时机:当用户提及或表达等价意图(帮我给视频添加字幕、给视频加字幕、视频打字幕、给视频生成字幕、添加字幕到视频、视频配字幕、字幕嵌入视频)时,调用此SKILL执行字幕添加任务。
openclaw skills install byted-kickart-video-subtitler为本地视频文件添加字幕。
| 限制项 | 限制值 | 说明 |
|---|---|---|
| 字幕总字数 | ≤3000字 | 字幕文本内容(不含标点符号)不得超过3000字 |
| 命令 | 功能 | 说明 |
|---|---|---|
python3.12 scripts/plan.py | 套餐查询 | 查询用户当前的 Ark Claw 套餐 |
python3.12 scripts/upload.py --file <视频路径> | 视频上传 | 上传本地视频文件获取媒资ID |
python3.12 scripts/subtitler.py --media-id <媒资ID> --captions <字幕配置文件> --output <输出文件> | 视频字幕添加 | 为视频添加字幕 |
字幕配置文件为JSON格式,包含一个字幕对象数组。单个字幕对象结构如下:
| 字段 | 类型 | 说明 |
|---|---|---|
text | string | 完整的字幕文本内容 |
start_time | number | 字幕开始显示时间(毫秒) |
end_time | number | 字幕结束显示时间(毫秒) |
words | array | 字级时间戳数组,包含每个字的详细时间信息 |
attribute | object | 字幕属性(预留字段,默认为空对象) |
基础规则:
生成步骤:
(end_time - start_time - 标点停顿时间) / 汉字数量示例计算:
对于字幕"足力健老人鞋,专为爸妈设计"(13个字符,含1个标点):
{
"text": "足力健老人鞋,专为爸妈设计",
"start_time": 1810,
"end_time": 5000,
"words": [
{"text": "足", "start_time": 1810, "end_time": 2000, "attribute": {}},
{"text": "力", "start_time": 2000, "end_time": 2180, "attribute": {}},
{"text": "健", "start_time": 2180, "end_time": 2380, "attribute": {}},
{"text": "老", "start_time": 2380, "end_time": 2580, "attribute": {}},
{"text": "人", "start_time": 2580, "end_time": 2790, "attribute": {}},
{"text": "鞋", "start_time": 2810, "end_time": 3030, "attribute": {}},
{"text": ",", "start_time": 3030, "end_time": 3030, "attribute": {}},
{"text": "专", "start_time": 3330, "end_time": 3550, "attribute": {}},
{"text": "为", "start_time": 3570, "end_time": 3790, "attribute": {}},
{"text": "爸", "start_time": 3810, "end_time": 4030, "attribute": {}},
{"text": "妈", "start_time": 4050, "end_time": 4270, "attribute": {}},
{"text": "设", "start_time": 4290, "end_time": 4510, "attribute": {}},
{"text": "计", "start_time": 4530, "end_time": 5000, "attribute": {}}
],
"attribute": {}
}
注意事项:
所有用户请求必须先完成以下3步校验,不得跳过:
echo "ARK_SKILL_API_BASE: $ARK_SKILL_API_BASE" && echo "ARK_SKILL_API_KEY: $ARK_SKILL_API_KEY" && echo "ACCESS_KEY_ID: $ACCESS_KEY_ID" && echo "SECRET_ACCESS_KEY: $SECRET_ACCESS_KEY"
ARK_SKILL_API_BASE 和 ARK_SKILL_API_KEY 均为非空值 → 鉴权通过ACCESS_KEY_ID 和 SECRET_ACCESS_KEY 均为非空值 → 鉴权通过请你提供火山账号AK&SK,用于检查火山创作Agent是否已开通套餐和有可用的创点
export ACCESS_KEY_ID=用户提供的ACCESS_KEY_ID值
export SECRET_ACCESS_KEY=用户提供的SECRET_ACCESS_KEY值
已完成ACCESS_KEY_ID/SECRET_ACCESS_KEY临时配置,当前配置仅在本次会话生效,不会持久化存储,请放心使用
export指定这两个环境变量,确保鉴权正常,无需用户重复配置python3.12 --version || (echo "❌ Python 3.12+ 未安装,请先安装Python 3.12" && exit 1)
python3.12 -m pip install -r ./scripts/requirements.txt
python3.12 -m scripts/plan.py
message 字段为有效截止时间(北京时间),校验通过message 小于等于当前时间,引导用户开通套餐,终止流程python3.12 -m scripts/upgrade.py
{"code":"0","message":"success","data":"{\"install_command\":\"\",\"latest_version\":\"1.0.0\",\"latest_version_number\":100000000,\"update_message\":\"\"}"}
latest_version:最新版本号(如 "1.0.0")install_command:新版本安装指令检测到技能有新版本 {latest_version},是否更新?(是/否)
install_command 安装新版本用户请求 → 强制前置校验 → 用户输入收集 → 视频字幕添加 → 结果返回
mkdir -p /tmp/openclaw/byted-kickart-video-subtitler/outputvideo_subtitle_<timestamp>_<random>.json步骤0:强制前置校验(必须按顺序执行,任意不通过直接终止流程)
步骤1:视频上传引导
/Users/user/video.mp4)https://example.com/video.mp4)步骤2:视频预处理
mkdir -p /tmp/openclaw/byted-kickart-video-subtitler/input
curl -L -o /tmp/openclaw/byted-kickart-video-subtitler/input/downloaded_video.mp4 "<视频URL>"
ls -la "<视频路径>"file /tmp/openclaw/byted-kickart-video-subtitler/input/downloaded_video.mp4 | grep -qE "ISO Media|MPEG v4|QuickTime" && echo "valid" || echo "invalid"
文件不可用,请检查路径是否正确,或确认文件为有效视频格式(仅支持 MP4/MOV)
步骤3:上传视频获取媒资信息
python3.12 scripts/upload.py --file <视频路径> 命令| 字段 | 类型 | 说明 |
|---|---|---|
id | string | 媒资ID(唯一标识) |
url | string | 视频访问URL |
duration | number | 视频时长(秒) |
步骤4:解析媒资信息:从上传输出中提取 id 作为媒资ID,提取 duration 用于字幕时间分配
您的视频时长为 {duration} 秒,建议字幕总字数不超过 {duration * 4} 字步骤6:字幕内容收集与校验
字幕字数超过限制(当前{count}字,限制3000字),请精简字幕内容后重新提交
步骤6:生成字幕配置
1
00:00:00,000 --> 00:00:02,000
第一条字幕内容
2
00:00:02,000 --> 00:00:04,000
第二条字幕内容
分句1:0-2000ms
分词:词1(0-500ms)、词2(500-1000ms)、词3(1000-1500ms)、词4(1500-2000ms)
分句2:2000-4000ms
分词:词5(2000-2500ms)、词6(2500-3000ms)、词7(3000-3500ms)、词8(3500-4000ms)
步骤7:字幕确认(添加到平台前,必须向用户确认)
步骤8:添加字幕:执行以下命令
python3.12 scripts/subtitler.py \
--media-id <媒资ID> \
--captions /tmp/openclaw/byted-kickart-video-subtitler/output/video_subtitle_<timestamp>_<random>.json \
--output /tmp/openclaw/byted-kickart-video-subtitler/output/subtitle_result_<timestamp>_<random>.json
--captions 参数值为字幕配置JSON文件的绝对路径(不是内联JSON字符串);由步骤6生成,保存在 /tmp/openclaw/byted-kickart-video-subtitler/output/ 目录下--output 参数值为结果JSON文件的绝对路径(不是视频文件路径);脚本会将字幕添加结果保存到此JSON文件步骤9:解析结果并提取视频URL
--output 指定的JSON文件内容video 字段值作为字幕添加后的视频URL| 字段 | 类型 | 说明 |
|---|---|---|
uuid | string | 字幕添加任务的唯一标识符 |
video | string | 字幕添加后的视频URL(包含鉴权参数) |
视频上传成功模板:
📤 视频上传成功!
🆔 媒资ID: {media_id}
🔗 视频URL: [点击查看]({url})
📊 分辨率: {width}x{height}
⏱️ 时长: {duration}秒
字幕添加成功模板:
✨ 字幕添加任务已完成!
🎥 [点击预览视频]({video})
📝 字幕已自动添加到视频中,您可以直接下载使用!
所有错误必须明确告知原因和可执行解决方案,禁止模糊提示!!!
| 错误码 | 错误描述 | 详细说明 | 用户处理建议 |
|---|---|---|---|
| 0 | 无返回值 | 接口调用成功,但服务返回结果为空 | 请稍后重试,如问题持续请联系火山技术支持 |
| 1400 | ParamErr参数错误 | 参数错误 | 联系技术支持 |
| 1402 | 创点不足 | 调用接口时,用户账户的创点额度不足 | 请前往 创点充值页面 充值创点或升级套餐 |
| 1410 | 服务ID不存在 | 调用接口时,输入参数中包含了不存在的服务ID | |
| 1411 | 输入分辨率错误 | 调用接口时,输入参数中的图片或视频分辨率不符合要求 | 请检查素材分辨率是否符合规格要求(如≥480p) |
| 1412 | 图片格式错误 | 调用接口时,输入参数中包含了非支持的图片格式 | 请检查图片格式是否为 jpg、png 等支持的格式 |
| 1413 | 无效的媒体URL错误 | 调用接口时,输入参数中包含了无效的媒体URL | 请检查您提供的URL是否正确,避免包含特殊字符或格式错误 |
| 1414 | 输入包含敏感信息错误 | 调用接口时,输入参数中包含了敏感信息,如个人隐私数据等 | 暂不可生成带人物的营销视频,请等待后续版本更新 |
| 1415 | 输出包含敏感信息错误 | 调用接口时,服务返回结果中包含了敏感信息,如个人隐私数据等 | 暂不可生成带人物的营销视频,请等待后续版本更新 |
| 1416 | 输入媒体数量错误 | 用户输入的素材数量超过限制 | 提供的媒体素材数量超出限制,多出的素材可能不会使用 |
| 1417 | 大模型调用错误 | 模型调用出错,通常是输入参数错误 | 媒体素材处理存在问题,请重新尝试,如问题持续请联系火山技术支持 |
| 1418 | 时长计费参数错误 | 提交时入参时间有问题 | 要求的成片时长不符合技能要求,请按照0-60s的时长限制提交制作需求,如问题持续请联系火山技术支持 |
| 1501 | 用户套餐过期 | 调用接口时,用户套餐已过期 | 请前往 套餐开通页面 开通套餐 |
| 1600 | 任务不存在 | 查询任务状态时,指定的任务ID不存在 | 请确认任务ID是否正确,或任务已被删除 |
| 100010 | 签名验证失败 | AK/SK签名验证失败 | 请检查您提供的火山鉴权AK/SK是否正确,可访问火山引擎控制台确认 |
| 100013 | 缺少服务权限 | 缺少iccloud_muse服务的RegisterArkClawCombo权限 | 您的企业账号未开通Kickart权限,请联系火山主账号管理员为您开通,或详询火山技术支持 |
| x01001 | AK/SK未配置 | 用户未配置AK/SK | 请输入火山鉴权的AK/SK,可访问火山引擎控制台获取 |
| x01010 | 有效套餐缺失 | 素材上传出现错误,通常是套餐原因 | 请前往 套餐开通页面 开通套餐 |
| A0101 | Session元数据格式错误 | 接口传入的Session元数据格式错误 | 稍后重试,如问题持续请联系火山技术支持 |
| A0402 | 文件校验不通过 | 用户输入的文件不符合校验要求 | 引导用户重新上传符合要求的文件 |
| 其他 | - | 未明确列出的其他错误情况 | 稍后重试,如问题持续请联系火山技术支持 |