Pdf MCP
P

Pdf MCP

一個基於Python的MCP服務器,提供PDF文檔的讀取、搜索和內容提取功能,支持分頁閱讀、全文搜索和圖像提取,並採用SQLite緩存實現持久化存儲。
2.5分
5.6K

什麼是PDF-MCP?

PDF-MCP是一個Model Context Protocol (MCP)服務器,專門用於處理PDF文檔。它允許AI助手(如Claude、Copilot等)直接訪問和操作PDF文件,包括讀取內容、搜索關鍵詞、提取圖片和獲取文檔信息。通過智能緩存機制,即使服務器重啟也能保持已處理文檔的緩存,提高重複訪問效率。

如何使用PDF-MCP?

PDF-MCP作為後臺服務運行,需要與支持MCP協議的AI客戶端配合使用。安裝後,在客戶端配置文件中添加服務器配置,重啟客戶端即可使用。AI助手會自動識別可用的PDF工具,用戶可以通過自然語言指令操作PDF文檔。

適用場景

PDF-MCP特別適合處理長文檔分析、研究報告閱讀、合同審查、學術論文摘要、多文檔信息提取等場景。當需要從PDF中快速獲取特定信息而不想手動翻閱時,這個工具能顯著提高效率。

主要功能

智能分頁閱讀
支持按頁碼範圍讀取PDF內容,避免一次性加載大文檔導致上下文溢出。可以指定單頁、多頁或連續頁面範圍。
全文搜索
在PDF文檔中搜索關鍵詞或短語,快速定位相關內容所在的頁面,無需手動翻閱整個文檔。
圖片提取
從PDF中提取嵌入的圖片,並以base64編碼的PNG格式返回,方便AI助手分析和描述圖片內容。
文檔信息獲取
獲取PDF的元數據,包括頁數、文件大小、創建日期、作者、標題等信息,以及預估的token數量。
目錄解析
自動解析PDF的目錄結構,顯示章節標題和對應的頁碼,幫助快速導航到感興趣的部分。
URL支持
不僅支持本地PDF文件,還可以直接從HTTP/HTTPS URL加載遠程PDF文檔,無需先下載到本地。
SQLite持久緩存
使用SQLite數據庫緩存已處理的PDF內容,緩存數據在服務器重啟後仍然保留,顯著提高重複訪問速度。
多客戶端支持
兼容Claude Desktop、VS Code Copilot、Codex CLI、Kiro等多種支持MCP協議的AI客戶端。
優勢
處理大文檔更高效:分頁讀取避免上下文限制,智能搜索快速定位信息
性能優化:SQLite緩存減少重複解析,提高響應速度
使用簡單:通過自然語言指令即可操作,無需學習複雜命令
跨會話持久性:緩存數據在服務器重啟後仍然有效
多功能集成:8個專用工具覆蓋PDF處理的常見需求
侷限性
需要客戶端支持:必須使用支持MCP協議的AI助手
掃描版PDF支持有限:對圖片型PDF的文字識別能力取決於原始文檔質量
複雜表格處理:對複雜格式的表格提取可能不夠完美
內存限制:極大文件(數百MB)可能受系統內存限制
需要配置:初次使用需要在客戶端進行簡單配置

如何使用

安裝PDF-MCP
通過Python包管理器pip安裝PDF-MCP服務器
配置AI客戶端
根據使用的AI客戶端(Claude、VS Code等),在配置文件中添加PDF-MCP服務器配置
重啟客戶端
重啟AI客戶端以加載PDF-MCP服務器
開始使用
在AI助手中通過自然語言指令操作PDF文檔

使用案例

年度報告分析
分析公司年度報告,提取關鍵財務數據和風險因素
學術論文研究
快速瀏覽多篇學術論文,提取研究方法和結論
合同審查
審查合同文檔中的關鍵條款和潛在風險
圖片資料整理
從產品手冊中提取所有產品圖片和說明

常見問題

PDF-MCP支持哪些AI客戶端?
能處理多大的PDF文件?
緩存數據存儲在哪裡?
如何處理掃描版PDF?
如何清除緩存?
支持中文PDF嗎?

相關資源

GitHub倉庫
PDF-MCP的源代碼、問題跟蹤和最新版本
PyPI項目頁面
Python包索引上的項目頁面,包含版本歷史和下載統計
MCP協議文檔
Model Context Protocol官方文檔和規範
如何構建PDF-MCP
開發者博客文章,介紹PDF-MCP的設計思路和實現細節
MCP服務器安全指南
關於MCP服務器安全最佳實踐的深度文章

安裝

複製以下命令到你的Client進行配置
{
  "mcpServers": {
    "pdf-mcp": {
      "command": "pdf-mcp"
    }
  }
}

{
  "mcpServers": {
    "pdf-mcp": {
      "command": "pdf-mcp",
      "args": [],
      "disabled": false
    }
  }
}

{
  "mcpServers": {
    "pdf-mcp": {
      "command": "uvx",
      "args": ["pdf-mcp"]
    }
  }
}
注意:您的密鑰屬於敏感信息,請勿與任何人分享。

替代品

V
Vestige
Vestige是一個基於認知科學的AI記憶引擎,通過實現預測誤差門控、FSRS-6間隔重複、記憶夢境等29個神經科學模塊,為AI提供長期記憶能力。包含3D可視化儀表板和21個MCP工具,完全本地運行,無需雲端。
Rust
5.4K
4.5分
M
Moltbrain
MoltBrain是一個為OpenClaw、MoltBook和Claude Code設計的長期記憶層插件,能夠自動學習和回憶項目上下文,提供智能搜索、觀察記錄、分析統計和持久化存儲功能。
TypeScript
6.3K
4.5分
B
Bm.md
一個功能豐富的Markdown排版工具,支持多種樣式主題和平臺適配,提供即時編輯預覽、圖片導出和API集成能力
TypeScript
5.5K
5分
S
Security Detections MCP
Security Detections MCP 是一個基於Model Context Protocol的服務器,允許LLM查詢統一的安全檢測規則數據庫,涵蓋Sigma、Splunk ESCU、Elastic和KQL格式。最新3.0版本升級為自主檢測工程平臺,可自動從威脅情報中提取TTPs、分析覆蓋差距、生成SIEM原生格式檢測規則、運行測試並驗證。項目包含71+工具、11個預構建工作流提示和知識圖譜系統,支持多SIEM平臺。
TypeScript
5.6K
4分
P
Paperbanana
PaperBanana是一個自動化生成學術圖表和統計圖的智能框架,支持從文本描述生成高質量的論文插圖,採用多智能體管道和迭代優化,提供CLI、Python API和MCP服務器等多種使用方式。
Python
7.9K
5分
F
Finlab Ai
FinLab AI是一個金融量化分析平臺,通過AI技術幫助用戶發現投資策略中的超額收益(alpha)。它提供豐富的數據集、回測框架和策略示例,支持自動化安裝與集成到主流AI編程助手。
7.3K
4分
B
Better Icons
一個提供超過20萬圖標搜索和檢索的MCP服務器和CLI工具,支持150多個圖標庫,幫助AI助手和開發者快速獲取和使用圖標。
TypeScript
6.7K
4.5分
A
Assistant Ui
assistant-ui是一個開源TypeScript/React庫,用於快速構建生產級AI聊天界面,提供可組合的UI組件、流式響應、無障礙訪問等功能,支持多種AI後端和模型。
TypeScript
6.7K
5分
M
Markdownify MCP
Markdownify是一個多功能文件轉換服務,支持將PDF、圖片、音頻等多種格式及網頁內容轉換為Markdown格式。
TypeScript
31.1K
5分
B
Baidu Map
已認證
百度地圖MCP Server是國內首個兼容MCP協議的地圖服務,提供地理編碼、路線規劃等10個標準化API接口,支持Python和Typescript快速接入,賦能智能體實現地圖相關功能。
Python
38.4K
4.5分
F
Firecrawl MCP Server
Firecrawl MCP Server是一個集成Firecrawl網頁抓取能力的模型上下文協議服務器,提供豐富的網頁抓取、搜索和內容提取功能。
TypeScript
122.4K
5分
S
Sequential Thinking MCP Server
一個基於MCP協議的結構化思維服務器,通過定義思考階段幫助分解複雜問題並生成總結
Python
31.7K
4.5分
E
Edgeone Pages MCP Server
EdgeOne Pages MCP是一個通過MCP協議快速部署HTML內容到EdgeOne Pages並獲取公開URL的服務
TypeScript
24.3K
4.8分
N
Notion Api MCP
已認證
一個基於Python的MCP服務器,通過Notion API提供高級待辦事項管理和內容組織功能,實現AI模型與Notion的無縫集成。
Python
17.3K
4.5分
C
Context7
Context7 MCP是一個為AI編程助手提供即時、版本特定文檔和代碼示例的服務,通過Model Context Protocol直接集成到提示中,解決LLM使用過時信息的問題。
TypeScript
80.2K
4.7分
M
Magic MCP
Magic Component Platform (MCP) 是一個AI驅動的UI組件生成工具,通過自然語言描述幫助開發者快速創建現代化UI組件,支持多種IDE集成。
JavaScript
20.7K
5分
AIBase
智啟未來,您的人工智慧解決方案智庫
© 2026AIBase