多媒體檔案分析工具 - 支援影片、圖片和音檔的視覺分析、語音轉錄和智慧檔名建議
Project description
MCP 媒體分析工具
完全本地執行的隱私媒體分析工具 - 支援影片、圖片和音檔的視覺分析、語音轉錄和智慧檔名建議,無需上傳數據到雲端。
核心優勢
- 🔐 完全本地執行:所有分析在本地完成,無需上傳任何數據
- 🛡️ 極度隱私保護:敏感媒體檔案永不離開你的設備
- ⚡ 離線可用:無網路亦可正常運作(local 模式)
- 🎯 三種工作模式:
- 📌 預設模式:本地優先 + 可選雲端 fallback
- 🔒 本地模式:100% 離線,完全隱私
- ☁️ 線上模式:純雲端(需 Gemini API)
功能
- 📹 影片分析:視覺內容(透過 LM Studio 視覺模型)、metadata、音訊轉錄
- 🖼️ 圖片分析:自動轉檔(HEIC→JPG)、視覺識別(透過 LM Studio 視覺模型)
- 🎵 音檔轉錄:本地 Whisper(Apple Silicon 最優化)
- ✨ 智慧檔名:LLM 生成有意義的檔名建議
快速開始
步驟 1:設定 MCP(只需這步)
將以下內容加入 ~/.cursor/mcp.json:
{
"mcpServers": {
"mcp-media-analyzer": {
"command": "uvx",
"args": ["mcp-media-analyzer"],
"env": {
"LM_STUDIO_URL": "http://localhost:1234/v1/chat/completions",
"LM_STUDIO_MODEL": "qwen/qwen3-vl-30b",
"GEMINI_API_KEY": "",
"WHISPER_MODEL": "mlx-community/whisper-large-v3-turbo",
"WHISPER_LANGUAGE": "zh"
}
}
}
}
步驟 2:預先下載模型(可選)
避免第一次使用時等待:
uvx --with huggingface_hub python -c "
from huggingface_hub import snapshot_download
print('下載 Whisper 模型中...')
snapshot_download('mlx-community/whisper-large-v3-turbo')
print('✓ 完成')
"
步驟 3:開始使用
重啟 Cursor 後,直接對話:
"分析這個影片 /path/to/video.mp4"
"幫我轉錄這個音檔"
"這張照片是在哪裡拍的?"
前提條件
1. 安裝 uv(套件管理工具)
# macOS / Linux
curl -LsSf https://astral.sh/uv/install.sh | sh
# Windows
powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"
2. 安裝 ffmpeg(媒體處理工具)
# macOS
brew install ffmpeg
# Linux
sudo apt-get install ffmpeg
# Windows
# 下載安裝包:https://ffmpeg.org/download.html
3. 安裝 LM Studio(本地視覺分析,可選)
用途:本地圖片/影片的視覺內容辨識(不上傳到雲端)
如果要使用本地視覺分析功能:
-
下載並安裝 LM Studio
-
在 LM Studio 中下載視覺模型(支援圖片輸入),推薦以下模型:
推薦模型 1:Qwen3-VL-30B
- 模型名稱:
qwen/qwen3-vl-30b - 大小:約 30GB
- 來源:Alibaba Qwen 團隊(開源)
- 優點:高精準度,支援繁體中文,視覺理解能力強
- 風險:需要較大記憶體(建議 32GB+ RAM)
推薦模型 2:Ministral-3-14B-Reasoning
- 模型名稱:
mistralai/ministral-3-14b-reasoning - 大小:約 14GB
- 來源:Mistral AI(法國 AI 公司)
- 優點:推理能力強,體積較小,適合硬體受限環境
- 風險:中文理解可能較弱,建議搭配英文提示詞
其他選擇:
llava,cogvlm(視硬體能力選擇) - 模型名稱:
-
啟動 LM Studio 本地伺服器:
- 開啟 LM Studio
- 載入已下載的視覺模型
- 點擊「Local Server」
- 點擊「Start Server」(預設
http://localhost:1234)
如果不想安裝 LM Studio:
- 可以只使用 Gemini API(需設定
GEMINI_API_KEY) - 或選擇「線上模式」直接用 Gemini
- 注意:圖片/影片會上傳到 Google 雲端進行分析
平台支援
| 功能 | 平台 | 工具 | 說明 |
|---|---|---|---|
| 圖片/影片辨識 | 全平台 | LM Studio | 本地視覺分析,隱私保護 |
| 全平台 | Gemini API | 雲端視覺分析(需 API key) | |
| 語音轉錄 | Apple Silicon | MLX-Whisper | 本地轉錄,快速 |
| 其他平台 | Gemini API | 雲端轉錄(需 API key) |
本地開發
如果你要修改程式碼,使用本地開發模式:
cd /path/to/mcp-media-analyzer
uv sync
uv run mcp-media-analyzer
對應的 mcp.json:
{
"mcpServers": {
"mcp-media-analyzer": {
"command": "uv",
"args": ["--directory", "/path/to/mcp-media-analyzer", "run", "mcp-media-analyzer"],
"env": {
"LM_STUDIO_URL": "http://localhost:1234/v1/chat/completions",
"LM_STUDIO_MODEL": "qwen/qwen3-vl-30b",
"GEMINI_API_KEY": "",
"WHISPER_MODEL": "mlx-community/whisper-large-v3-turbo",
"WHISPER_LANGUAGE": "zh"
}
}
}
}
環境變數說明
| 變數 | 必要 | 預設值 | 說明 |
|---|---|---|---|
LM_STUDIO_URL |
❌ | http://localhost:1234/v1/chat/completions |
LM Studio API 端點 |
LM_STUDIO_MODEL |
❌ | qwen/qwen3-vl-30b |
視覺分析模型 |
GEMINI_API_KEY |
❌ | 無 | Google Gemini API key |
WHISPER_MODEL |
❌ | mlx-community/whisper-large-v3-turbo |
Whisper 模型 |
WHISPER_LANGUAGE |
❌ | zh |
轉錄語言 |
使用
分析單一檔案
# 預設模式(本地優先 + Gemini fallback)
{
"file_path": "video.mp4",
"mode": "default"
}
# 本地模式(完全離線)
{
"file_path": "video.mp4",
"mode": "local"
}
# 線上模式(直接用 Gemini)
{
"file_path": "audio.mp3",
"mode": "online"
}
# 音檔分析
{
"file_path": "recording.wav",
"mode": "default"
}
模式對比
本地模式(Local)- 🏆 完全隱私保護
✅ 適合機密資料、企業檔案
- 視覺分析:LM Studio only(本地)
- 語音轉錄:Whisper only(本地)
- 檔名建議:LM Studio only(本地)
- 所有數據永不離開你的設備
- 100% 離線可用
預設模式(Default)- 推薦
✅ 本地優先 + 可選雲端
- 視覺分析:LM Studio → Gemini fallback
- 語音轉錄:Whisper → Gemini fallback
- 檔名建議:LM Studio → Gemini fallback
- 適合:平衡隱私與質量
線上模式(Online)- 🚀 最聰明、最快速
⚠️ 需要 Gemini API key
- 視覺分析:Gemini
- 語音轉錄:Gemini
- 檔名建議:Gemini
- 最高準確度、最快處理速度
- 適合:質量優先、對隱私要求低
版本
1.0.3(2026-02)
- 預設使用 local Whisper、整段轉錄(不切段)
- 新增選項 use_batch:長音檔可設
true改為分段轉錄 - 完全移除幻覺過濾,所有轉錄段落皆保留
- 回傳給 Agent 的結果加入 後續建議(Agent TODO):請依據逐字稿進行校稿與排版
- 移除
batch_analyze工具,僅保留analyze單檔分析
1.0.2(2026-02)
- 本地 Whisper 分段轉錄:長段落(>200 字)不再誤判為幻覺,保留英文/後半中文內容
- 幻覺判斷 prompt:整段中英文連貫敘述不再標記為幻覺
- 建議檔名:一律使用繁體中文(台灣用字)
授權
MIT
支援
如有問題,請提交 issue 或聯絡開發者。
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mcp_media_analyzer-1.0.3.tar.gz.
File metadata
- Download URL: mcp_media_analyzer-1.0.3.tar.gz
- Upload date:
- Size: 17.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
433500437b6e3005f0f19904285bf0e716ace931ccb4a7d918a3a949a104649a
|
|
| MD5 |
e96b9430d93550de5195ab3b2d6bb39d
|
|
| BLAKE2b-256 |
f4e732773709b543b98c3bd17623d9d9fd6d0cca484495e0e7f459ac225499c7
|
File details
Details for the file mcp_media_analyzer-1.0.3-py3-none-any.whl.
File metadata
- Download URL: mcp_media_analyzer-1.0.3-py3-none-any.whl
- Upload date:
- Size: 17.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ec7a1b49d69d19b0fdfe497ba236be13a931e8e63d37f4edc329d1e3af1f872a
|
|
| MD5 |
c6847fe86f21ff19801fd327b2cd5918
|
|
| BLAKE2b-256 |
b462d44a4c96abffd74e7f821d39f47999d7b6883d0370029f7d83e349b69081
|