如果你是从视频评论区过来的,先别急着把链接全打开。

这套东西可以帮你搭一条 AI 电影解说的生产链路,但它不是自动赚钱机器,也不会替你解决版权、平台规则、选片眼光和文案审美。它更适合做一件小事:让你先把第一条片子跑出来。

很多人想做电影解说,第一步就卡死了。找片、拆剧情、写解说词、配音、找 BGM、合成视频,每一步都不算特别神秘,但连在一起就很劝退。Narrator AI 这套开源工具的价值,不是保证你做成账号,而是把这条链路拆成可以交给 AI Agent 调用的步骤。

它到底分成哪两部分

这里有两个仓库,不要混在一起看。

第一个是 CLI 工具:

https://github.com/NarratorAI-Studio/narrator-ai-cli

CLI 可以理解成真正干活的命令行工具。安装以后,你可以在终端里配置 API Key、查看版本、调用电影解说相关能力。

第二个是 Skill:

https://github.com/NarratorAI-Studio/narrator-ai-cli-skill

Skill 更像是给 AI Agent 看的操作说明。你用 Claude Code、Cursor、Windsurf、OpenClaw 这类能读 Skill 的工具时,它需要知道什么时候该调用哪个命令、怎么串起流程、遇到错误怎么继续。

简单说:CLI 是手,Skill 是说明书。

你先准备这几样

新手不要一上来就问“能不能爆”。先确认环境能不能跑。

你需要准备:

  • Python 3.10+
  • Git
  • 一个能读 Skill 的 AI Agent,比如 Claude Code、Cursor、Windsurf、OpenClaw
  • Narrator AI 的 API Key
  • 一个测试片名

这里最容易卡的是 API Key 和本机环境。Python 没装好、Git 不在 PATH 里、API Key 没配上,都会让你误以为“工具不好用”。先把底座弄清楚,再谈创作。

Windows 怎么安装

在 Windows 的 PowerShell 或 CMD 里运行:

python -c "import urllib.request; exec(urllib.request.urlopen('https://raw.githubusercontent.com/NarratorAI-Studio/narrator-ai-cli/main/install.py').read())"

装完以后先验证版本:

narrator-ai-cli --version

能看到版本号,再配置 API Key:

narrator-ai-cli config set app_key your_api_key

这里的 your_api_key 要换成你自己的 key。不要把真实 key 发到评论区、截图里,也不要交给来路不明的脚本。

第一条片子只验收五件事

第一条不要追求爆款,也不要先纠结账号定位。先跑一条 1 分钟以内的短解说,验证这五件事:

  1. 能不能搜到片名
  2. 能不能生成解说文案
  3. 能不能选配音和 BGM
  4. 能不能合成一条视频
  5. 输出的视频能不能下载

这五件事跑通,才说明你的工具链是通的。至于文案好不好、节奏对不对、画面能不能留住人,那是下一层问题。

如果第一条连下载都没有跑出来,就别急着研究爆款模板。

工具替不了你解决的坑

电影解说这件事,真正麻烦的地方不只是剪辑。

版权要自己看。不是所有电影素材都能随便用,也不是加了配音和字幕就一定安全。

平台规则要自己看。不同平台对搬运、二创、影视内容、营销引导的边界不一样,不能只听别人一句“可以发”。

选片要自己判断。悬疑、搞笑、怀旧、冷知识、冷门佳片,背后是完全不同的观众和账号方向。

文案要人工改。AI 生成的解说词可以做初稿,但如果你不改,很容易变成流水账,或者每一条都像同一个模板吐出来的。

账号定位也要自己想。你到底是做剧情复述、观影推荐、影视冷知识,还是情绪向解说?这不是 CLI 能替你决定的。

我建议你怎么开始

先选一部你熟悉的电影。

不要选你完全没看过、只是觉得流量大的片子。第一条的目标不是冲播放量,而是检查你对这个流程有没有修改欲望。

跑出一条 1 分钟以内的短解说以后,自己看一遍:

  • 文案有没有你想改的地方
  • 配音听起来像不像人
  • BGM 有没有抢话
  • 字幕有没有错
  • 画面和解说有没有对上

如果第一条你都懒得改,那这个方向大概率不适合你。

如果你看完以后马上想动手改文案、调节奏、换配音,那才说明可以继续往下做。

AI 工具最适合帮你把第一条链路搭起来。真正决定你能不能做下去的,还是你愿不愿意一条一条改到能看。