Install
openclaw skills install emby-tv-organizerEmby 电视剧媒体库整理助手。当用户提供一个电视剧文件夹路径,需要按照 Emby 标准命名规范整理文件结构、识别季号集号、处理特别篇/SP/OVA、生成重命名对照表并输出 Excel 时,使用此 Skill。 典型触发场景:「帮我整理这个电视剧文件夹」「按 Emby 规范重命名」「扫描 /vol3/... 文件夹并生成整理方案」。
openclaw skills install emby-tv-organizer接收用户提供的电视剧文件夹路径,扫描文件结构,按照 Emby 标准命名规范分析并生成整理方案。 严格遵守"先预览、后执行"原则:在用户确认前,不执行任何实际的重命名或移动操作。
电视剧名称 (年份)/
Season 01/
电视剧名称 (年份) - S01E01.ext
电视剧名称 (年份) - S01E01 - 集名称.ext ← 原文件含集名称时保留
电视剧名称 (年份) - S01E01.zh-CN.srt
电视剧名称 (年份) - S01E01 - 集名称.zh-CN.srt ← 字幕同步保留集名称
Season 02/
电视剧名称 (年份) - S02E01.ext
Season 00/
特别篇原文件名.ext(文件名不变)
SP原文件名.ext(文件名不变)
当原文件名中包含集名称/话名(即集号之后的标题性文字)时,应在重命名后的文件名中保留,格式为:
电视剧名称 (年份) - S01E01 - 集名称.ext
识别集名称的方法:
第1话、E01、EP01等)之后、画质/编码/发布组等噪音标签之前的文字典型示例:
| 原始文件名 | 提取的集号 | 提取的集名称 | 重命名结果 |
|---|---|---|---|
01_《刀剑神域》第1话 剑的世界_高清 1080P+.mp4 | S01E01 | 剑的世界 | 刀剑神域 (2012) - S01E01 - 剑的世界.mp4 |
第2话 灰色之剑.mkv | S01E02 | 灰色之剑 | 刀剑神域 (2012) - S01E02 - 灰色之剑.mkv |
[ANi] 芙莉莲 - 05 [1080P].mkv | S01E05 | (无) | 葬送的芙莉莲 (2023) - S01E05.mkv |
布鲁伊.S01E01.mkv | S01E01 | (无) | 布鲁伊 (2018) - S01E01.mkv |
噪音排除规则(以下内容不属于集名称,应剥离):
1080P、1080p、720P、4K、2160px264、x265、HEVC、H.264、H.265WEB-DL、WEBRip、BluRay、BDRip、HDTVAAC、DDP5.1、DTSHDR、DV、10bit[] 或 【】 包围的内容_高清、+、- 结尾的无意义字符.mkv、.mp4 等- 输入文件夹路径:(用户提供的原始路径)
- 识别电视剧名称:(从路径/文件名提取的原始名称)
- 建议电视剧名称:(清理后的标准名称)
- 年份:(识别到的年份,或"需要人工确认")
- 识别到的季:(如:第1季、第2季、第3季)
- 是否包含特别篇:是/否
- 是否存在需要人工确认的文件:是/否
- 建议整理后的根目录:(如:/vol3/1000/Movies/TVPlay/布鲁伊 (2018))
用树形结构展示整理后的完整目录。
| 序号 | 原始路径/文件名 | 建议路径/文件名 | 文件类型 | 识别信息 | 说明 |
|---|
列出所有无法自动判断的条目,如:
Excel 文件名:电视剧名称_yyyyMMdd_HHmmss.xlsx
Excel 保存路径:<用户指定路径>/电视剧名称_yyyyMMdd_HHmmss.xlsx
保存路径规则:
- 如果用户在本次请求中明确指定了保存路径(如「保存到 /vol3/backup」),则使用用户指定的路径。
- 如果用户未指定路径,使用默认路径:
/vol2/1000/SyncFile/OpenClawSync。- 在输出整理方案时,需向用户确认 Excel 保存路径,例如: 「Excel 将保存到:
/vol2/1000/SyncFile/OpenClawSync(默认),如需保存到其他位置请告知。」
输出整理方案后,必须停止并等待用户明确确认,不得自动继续执行。
⚠️ 关键:必须通过运行 Python 脚本生成 Excel,严禁手动写入 .xlsx 文件内容!
.xlsx 文件是 ZIP 压缩的 XML 格式,手动写入会生成损坏的文件。必须使用 generate_excel.py 脚本通过 openpyxl 库正确生成。
生成步骤(严格按顺序执行):
构造 JSON 数据:将整理结果组装为如下结构的 JSON:
{
"show_name": "电视剧名称",
"output_dir": "/vol2/1000/SyncFile/OpenClawSync",
"records": [
{
"序号": 1,
"电视剧名称": "刀剑神域",
"年份": "2012",
"原始路径": "/vol3/1000/Movies/TVPlay/[动漫]刀剑神域/01_《刀剑神域》第1话 剑的世界_高清 1080P+.mp4",
"原始文件名": "01_《刀剑神域》第1话 剑的世界_高清 1080P+.mp4",
"新路径": "/vol3/1000/Movies/TVPlay/刀剑神域 (2012)/Season 01/刀剑神域 (2012) - S01E01 - 剑的世界.mp4",
"新文件名": "刀剑神域 (2012) - S01E01 - 剑的世界.mp4",
"季号": "S01",
"集号": "E01",
"集名称": "剑的世界",
"文件类型": "普通剧集",
"是否重命名": "是",
"是否移动": "是",
"处理状态": "待确认",
"说明": "保留集名称"
}
]
}
写入临时 JSON 文件:将 JSON 数据保存到临时文件,例如 /tmp/emby_data_<timestamp>.json:
Write tool → file_path: /tmp/emby_data_<timestamp>.json, content: <上述JSON>
通过 Bash 运行脚本:使用 Bash 工具执行 Python 命令:
python "C:/Users/Admin/.workbuddy/skills/emby-tv-organizer/scripts/generate_excel.py" --data /tmp/emby_data_<timestamp>.json --output <保存目录>
确认输出:脚本成功后会打印 [OK] Excel 已生成:<完整路径>,将此路径报告给用户。
脚本路径:C:/Users/Admin/.workbuddy/skills/emby-tv-organizer/scripts/generate_excel.py
保存目录规则:
/vol2/1000/SyncFile/OpenClawSync文件名格式:电视剧名称_yyyyMMdd_HHmmss.xlsx(非法文件名字符自动替换为下划线)
输出效果:列宽适配长路径(路径列 75 字符宽),首行+首列冻结,自动筛选,状态颜色标记,统计 Sheet 含边框样式
❌ 错误做法:直接用 Write 工具将内容写入 .xlsx 文件(会产生 XML 原文而非有效 Excel) ✅ 正确做法:写 JSON → Bash 运行 Python 脚本 → openpyxl 生成有效 .xlsx
| 类型 | 示例 |
|---|---|
| 分类标签 | [动漫] [电视剧] [美剧] [日剧] [韩剧] |
| 季数说明 | 1-3季 第一季 第二季 全集 完结 |
| 画质信息 | 1080p 2160p 4K 720p |
| 编码信息 | x264 x265 HEVC AVC WEB-DL WEBRip BluRay BDRip HDTV |
| 音频信息 | AAC DDP5.1 DD+5.1 Atmos DTS H.264 H.265 |
| 色彩信息 | HDR DV Dolby Vision 10bit 8bit |
| 其他 | 发布组名称、网站广告、无意义中括号内容、多余空格/点号/横线 |
示例:
[动漫]布鲁伊 1-3季→ 剧名:布鲁伊
以下格式均应被识别并统一转换为 SxxExx:
| 原始格式 | 示例 | 转换结果 |
|---|---|---|
S01E01 / s01e01 | S01E01 | S01E01 |
S1E1 | S1E1 | S01E01 |
1x01 | 1x01 | S01E01 |
EP01 / Ep.01 / E01 | EP01 | E01(季号需另行判断) |
第01集 / 第1集 | 第1集 | E01 |
01话 / 第01话 | 第01话 | E01 |
Episode 01 | Episode 01 | E01 |
纯数字 01 | 01 | E01(季号需另行判断) |
季号判断优先级:
S01、第一季等)→ 直接使用。Season 02、第二季)→ 使用该季号。1-3季 等范围说明,但单文件无法判断 → 标注「需要人工确认」。多集合并:多集文件命名为 电视剧名称 (年份) - S01E01-E02.ext。
以下关键词命中时,归入 Season 00,文件名保持原样不变:
特别篇、SP、Special、OVA、OAD、番外、花絮、幕后、Making Of
预告、Trailer、PV、OP、ED、NCOP、NCED、采访、访谈
| 文件类型 | 扩展名 |
|---|---|
| 视频(普通剧集) | .mkv .mp4 .avi .ts .m2ts |
| 字幕 | .srt .ass .ssa .sub .idx |
| NFO | .nfo |
| 图片 | .jpg .jpeg .png .webp .tbn |
| 其他 | 以上之外的所有文件 |
字幕命名规则:普通剧集字幕与视频同名,保留语言标签,集名称同步保留:
布鲁伊 (2018) - S01E01.mkv
布鲁伊 (2018) - S01E01 - 玩游戏.mkv ← 含集名称的视频
布鲁伊 (2018) - S01E01.zh-CN.srt
布鲁伊 (2018) - S01E01 - 玩游戏.zh-CN.srt ← 字幕同步保留集名称
布鲁伊 (2018) - S01E01.en.srt
Season 00 中的特别篇字幕,保持原文件名风格,不强制改名。
调用 scripts/generate_excel.py 时,Excel 需包含以下字段:
| 字段 | 说明 |
|---|---|
| 序号 | 从 1 开始递增 |
| 电视剧名称 | 整理后的标准剧名 |
| 年份 | 首播年份,未知填「需要人工确认」 |
| 原始路径 | 文件整理前的完整路径 |
| 原始文件名 | 文件整理前的文件名 |
| 新路径 | 文件整理后的完整路径 |
| 新文件名 | 文件整理后的文件名 |
| 季号 | 如 S01、S02、S00 |
| 集号 | 如 E01、E02;特别篇可填「特别篇」或留空 |
| 集名称 | 原文件中的集标题/话名,如「剑的世界」;无则留空 |
| 文件类型 | 普通剧集/特别篇/SP/OVA/番外/花絮/字幕/NFO/图片/其他 |
| 是否重命名 | 是/否 |
| 是否移动 | 是/否 |
| 处理状态 | 已整理/待确认/跳过/失败 |
| 说明 | 如「特别篇放入 Season 00,名称不变」「保留集名称:剑的世界」 |
scripts/generate_excel.pyreferences/episode_patterns.md