ワンクリックで
video-screenshot
视频截图提取工具。从录屏视频(微信聊天录屏、会议录屏等)中自动抽取关键帧、去重并保存为图片文件,可用作法律证据。支持场景变化检测、关键帧提取、固定间隔、智能去重四种策略,配合内容区 dHash、像素差异、SSIM、滚动帧合并、OCR 文本去重和可选复合复核模式;当前模型支持图像输入时可复核被丢弃候选帧,文字模型跳过复核。触发词:视频截图、录屏截图、聊天记录截图、抽帧去重、视频截帧、视频关键帧提取。不要用于:视频压缩、视频剪辑、音频提取。
メニュー
视频截图提取工具。从录屏视频(微信聊天录屏、会议录屏等)中自动抽取关键帧、去重并保存为图片文件,可用作法律证据。支持场景变化检测、关键帧提取、固定间隔、智能去重四种策略,配合内容区 dHash、像素差异、SSIM、滚动帧合并、OCR 文本去重和可选复合复核模式;当前模型支持图像输入时可复核被丢弃候选帧,文字模型跳过复核。触发词:视频截图、录屏截图、聊天记录截图、抽帧去重、视频截帧、视频关键帧提取。不要用于:视频压缩、视频剪辑、音频提取。
SOC 職業分類に基づく
基于现有文章、专栏、课程讲稿、逐字稿、访谈、课件、会议纪要、案例材料、PDF 文本、Word 文档和笔记等内容资产,判断它们最适合转化为书、小册子、课程、系列文章、实务手册或知识库,并输出精简策划意见;用户提到“把现有内容整理成书”“判断素材适合做书还是课程”“把文章/直播稿/课程稿/笔记重组成知识产品”等场景时,应使用本技能。
使用本地 FunASR 服务将音频或视频文件转录为带时间戳的 Markdown 文件,支持 mp4、mov、mp3、wav、m4a 等常见格式。本技能应在用户需要语音转文字、会议记录、视频字幕、播客转录时使用。
Git 工作流安全助手。本技能应在需要执行分支管理、Monorepo 安全合并、PR 创建/审查/合并、冲突处理、cherry-pick、安全回退,以及 stale/已合并分支审计与清理(branch cleanup,含 squash/rebase merge 校验)时使用。不要用于:批量生成提交信息、项目任务分配、长期任务状态管理或本地多 Agent 会话编排。
本技能应在用户需要 OCR、扫描识别、图片文字识别、文档识别,或将 PDF、图片、Office 文档、URL 转换为 Markdown 时使用。检测到法律材料时可进行保守的法律术语与文书结构优化。不要用于法律事实判断、补写缺失内容、语义改写、印章深度识别或图表实体分析。
Skill 质量验收与格式审查工具,也可称 Skilllint。本技能应在用户需要审查 Claude Code Skill 的目录结构、Frontmatter、引用一致性、发布版本、业务流深度、可评估性和安全风险时使用。不要用于:创建新技能、代码审查、应用功能测试、通用编程任务。
转录稿纠错与轻度优化。本技能应在用户需要按用户词典纠正 ASR 转录稿同音字与英文专有名称漂移时使用。不要用于:重写为课程章节、报告、总结,或完全空白的素材创作。
| name | video-screenshot |
| description | 视频截图提取工具。从录屏视频(微信聊天录屏、会议录屏等)中自动抽取关键帧、去重并保存为图片文件,可用作法律证据。支持场景变化检测、关键帧提取、固定间隔、智能去重四种策略,配合内容区 dHash、像素差异、SSIM、滚动帧合并、OCR 文本去重和可选复合复核模式;当前模型支持图像输入时可复核被丢弃候选帧,文字模型跳过复核。触发词:视频截图、录屏截图、聊天记录截图、抽帧去重、视频截帧、视频关键帧提取。不要用于:视频压缩、视频剪辑、音频提取。 |
| version | 0.3.2 |
| author | 杨卫薪律师(微信ywxlaw) |
| homepage | https://github.com/cat-xierluo/legal-skills |
| license | MIT |
从录屏视频(微信聊天录屏、会议录屏等)中自动抽取关键帧、去重并保存为可用作法律证据的图片文件。独立 Python CLI,无 Django 依赖。
确认用户提供的视频文件路径。支持常见视频格式:.mp4 .mov .avi .mkv .webm .flv .wmv .ts
默认配置(大多数场景无需调整):
| 参数 | 默认值 | 说明 |
|---|---|---|
| 抽帧策略 | scene | 场景变化检测 |
| 场景阈值 | 0.10 | 变化幅度阈值(越小越敏感) |
| 定期采样间隔 | 2.0s | 静态画面保底采样(0=禁用) |
| 内容区裁剪 | 上 12% / 下 12% / 左右 4% | 排除状态栏、导航栏和边缘黑边后再比较 |
| dHash 去重阈值 | 4 | 对内容区计算汉明距离(0=禁用) |
| SSIM 阈值 | 0.93 | 结构相似度补充去重(0=禁用) |
| 滚动帧合并 | 关闭 | 需显式 --scroll-merge 开启 |
| OCR 去重 | 关闭 | 需显式开启 |
| 最小时间间隔 | 0.5s | 抑制同一时间段内过密保留帧(0=禁用) |
| 复核候选帧 | 关闭 | 需显式 --keep-drop-candidates 开启 |
| 最长边像素 | 0 | 保持原始分辨率(可设如 1920 限制尺寸) |
| JPEG 质量 | 2 | 最高质量(范围 1-31,越小越清晰) |
详细参数说明见 references/strategy-and-params.md,安装指南见 references/setup.md。
# 默认:场景检测 + 图像去重
uv run scripts/extract.py -i <视频文件路径>
# 场景检测 + OCR 去重(推荐用于聊天录屏)
uv run scripts/extract.py -i <视频文件路径> --ocr-dedup
# 复合复核模式:保留被算法丢弃的候选帧,供多模态模型回查
uv run scripts/extract.py -i <视频文件路径> --ocr-dedup --keep-drop-candidates
# 固定间隔,每 0.5 秒一帧
uv run scripts/extract.py -i <视频文件路径> -s interval --interval 0.5
# 关键帧提取,不去重
uv run scripts/extract.py -i <视频文件路径> -s keyframe -d 0
# 自定义输出目录
uv run scripts/extract.py -i <视频文件路径> -o /evidence/case_001/
# 更严格的场景检测(更多帧)
uv run scripts/extract.py -i <视频文件路径> --scene-threshold 0.15
# 禁用滚动帧合并(需要逐步滚动全过程时)
uv run scripts/extract.py -i <视频文件路径> --no-scroll-merge
输出目录包含:
| 文件 | 说明 |
|---|---|
frame_001_00m00s.jpg | 保留帧(序号 + 时间戳命名) |
frame_002_00m03s.jpg | 下一帧 |
_report.json | 元数据报告(输入信息、去重统计、每帧 SHA256) |
_review_candidates/ | 仅在 --keep-drop-candidates 开启时生成,保存被算法丢弃但可复核的候选帧 |
_report.json 可用于证据链追溯,记录了每帧的 SHA256 哈希、捕获时间戳和去重统计;复合模式下还会记录 review.drop_candidates,列明候选帧文件名、丢弃原因和时间戳。
归档目录中的 frames/ 只保留 _report.json 清单内的本次有效帧。每次运行前会清理输出目录中旧的 frame_*.jpg 和本工具报告文件,避免旧帧混入新结果;不会删除其他用户文件。
当用户担心算法漏掉关键截图,或反馈同一秒内截图过多时,优先使用复合复核模式:
uv run scripts/extract.py -i <视频文件路径> --ocr-dedup --keep-drop-candidates。_report.json 中 review.drop_candidates 记录的候选帧,重点看 min_gap、quality_*、duplicate_ssim、duplicate_scroll、ocr_duplicate 等原因对应的图片。_review_candidates/ 已生成但未做图像判断。| 策略 | 说明 | 推荐场景 |
|---|---|---|
scene | 场景变化检测,画面有显著变化时提取 | 聊天录屏、操作录屏(默认推荐) |
keyframe | 仅提取视频关键帧(I 帧) | 压缩视频、快速浏览 |
interval | 固定时间间隔提取 | 需要均匀时间采样 |
smart | ffmpeg 智能去重 | 不确定时尝试 |
八级级联去重 + 可选过滤,每一级通过后才进入下一级:
--filter-blur 开启--ocr-dedup 开启--keep-drop-candidates 保存被前述规则丢弃的候选帧和原因,供多模态复核| 依赖 | 版本要求 | 安装方式 |
|---|---|---|
ffmpeg | ≥ 5.0 | brew install ffmpeg |
Python | ≥ 3.10 | 系统自带或 brew install python |
uv | 最新 | brew install uv |
Pillow | ≥ 10.0 | 自动安装(PEP 723 内联依赖) |
rapidocr-onnxruntime | ≥ 1.0 | pip install rapidocr-onnxruntime(仅 OCR 去重需要) |
pdf:输出帧可组装为 PDF 证据包paddle-ocr:需要更高质量的 OCR 内容识别时,用输出帧作为输入legal-text-format:帧内容 OCR 后格式化video-compressor:抽帧前先压缩视频,减小 I/O 时间--max-size 参数_report.json 始终生成,确保证据可追溯