Skip to main content

A powerful MCP server for AI-driven Jupyter Notebook management and execution

Project description

🪐 Jupyter MCP Server

Jupyter MCP Server

专门为AI连接与管理Jupyter Notebook而开发的MCP服务

ChengJiale150 开发

Python License Version mcp-registry

English | 中文

📖 目录

🎯 项目简介

Jupyter MCP Server 是一个基于 Model Context Protocol (MCP) 的服务,为目前最先进的的AI IDE(如 Cursor) 与CLI工具(如Gemini CLI)提供连接与管理Jupyter Notebook的能力。使得AI能够操作Notebook,进行数据分析、可视化、机器学习等任务。

🤔 为什么需要Jupyter MCP Server

Jupyter Notebook 是数据科学家最常用的工具之一,它提供了一个交互式的环境,使其可以方便地进行数据分析、可视化、机器学习等探索性任务。然而,由于Notebook自身的格式限制,使得其难以像纯文本文件(如Markdown、Python文件)一样被AI直接理解。

现有的提供操作Notebook的工具或MCP服务,要么仅能阅读与编辑Notebook,要么仅能操纵单个Notebook,难以满足同时操纵多个Notebook的复杂需求。此外,大多数工具也不支持多模态输出,无法充分利用目前最先进的多模态大模型(如Gemini 2.5)的强大图文理解能力。

Jupyter MCP Server 就是为了解决这个问题而开发的。它通过MCP协议,向AI提供了管理Jupyter Kernel与Notebook的工具,使其能够操纵多个Notebook进行交互式的任务执行,并输出多模态结果,助力数据科学家提高分析效率。

✨ 关键亮点

  • 🔌 MCP兼容: 能够在任何支持MCP协议的IDE或CLI工具中使用
  • 📚 多Notebook管理: 支持同时管理多个Notebook
  • 🔁 交互式执行: 能够根据Cell的输出自动调整执行策略
  • 📊 多模态输出: 支持输出多模态结果,如文本、图片、表格等

🔧 工具一览

Notebook管理模块

名称 描述 说明
connect_notebook 连接/创建指定路径的Notebook 因为需要启动Kernel,工具执行时间较长(10s~30s)
list_notebook 列出所有目前连接的Notebook 用于查看目前已经连接的Notebook,方便多Notebook任务执行
restart_notebook 重启指定名称的Notebook 清除所有导入包与变量
read_notebook 读取指定名称的Notebook的源内容(不包含输出) 用于查看Notebook的源内容,仅在明确要求时才使用

Cell基本功能模块

名称 描述 说明
list_cell 列出指定名称的Notebook的所有Cell的基本信息 用于定位Cell的索引与作用
read_cell 读取指定名称的Notebook指定索引的Cell内容 支持图像、表格、文本等多种输出
delete_cell 删除指定名称的Notebook指定索引的Cell
insert_cell 在指定名称的Notebook指定索引处上方/下方插入Cell
execute_cell 执行指定名称的Notebook指定索引的Cell 返回Cell的输出结果
overwrite_cell 覆盖指定名称的Notebook指定索引的Cell内容 用于修改Cell内容

Cell高级集成功能模块

名称 描述 说明
append_execute_cell 在Notebook末尾添加并执行Cell insert+execute的组合为高频操作,将其组合减少工具的调用次数
execute_temporary_cell 执行临时代码块(不存储到Notebook中) 用于进行魔法指令执行、代码片段调试、查看中间变量取值等临时操作

工具的具体内容详见工具文档

🛠️ 快速上手

环境准备

安装Jupyter MCP Server

uvx 快速安装(推荐)

在安装uv后,直接配置MCP的JSON格式即可,示例如下:

{
    "mcpServers":{
        "Jupyter-MCP-Server":{
            "command": "uvx",
            "args": [
                "better-jupyter-mcp-server"
            ],
            "env": {},
            "transport": "stdio"
        }
    }
}

具体客户端集成详见集成文档

源代码
  1. 克隆项目并安装依赖
git clone https://github.com/ChengJiale150/jupyter-mcp-server
cd jupyter-mcp-server
uv sync
  1. (可选)配置config.toml

进入src/config.toml文件,根据需要配置参数(如是否允许返回图片数据)

  1. 启动Jupyter MCP Server
uv run fastmcp run src/better_jupyter_mcp_server/server.py

如果成功启动,会输出类似如下信息代表启动成功:

[09/14/25 20:14:59] INFO     Starting MCP server 'Jupyter-MCP-Server' with transport 'stdio'  
  1. 配置标准JSON格式
{
    "mcpServers":{
        "Jupyter-MCP-Server":{
            "command": "uv",
            "args": [
                "run",
                "--directory",
                "your/path/to/jupyter-mcp-server",
                "src/better_jupyter_mcp_server/server.py"
            ],
            "env": {},
            "transport": "stdio"
        }
    }
}

具体客户端集成详见集成文档

启动Jupyter

在正式使用前,需要连接Jupyter Server,这里介绍如何在本地启动Jupyter Server:

  1. 打开终端并激活环境:

打开计算机终端命令行,并激活环境

对于使用conda(Anaconda)的用户,可以使用以下命令激活环境:

conda activate your_environment_name

这里为了方便起见,这里可以直接使用base环境(conda activate base)

然后切换到你当前的项目目录,方便后续的文件操作

cd your/path/to/your/project
  1. 安装必要依赖:
pip uninstall -y pycrdt datalayer_pycrdt
pip install jupyter nbformat datalayer_pycrdt jupyter-collaboration
  1. 启动Jupyter Server:

使用下述命令启动Jupyter Server,其中YOUR_TOKEN为认证Token,可自行修改

jupyter lab --port 8888 --IdentityProvider.token YOUR_TOKEN

成功启动后会弹出浏览器窗口,你可以在此查看根路径是否为工程目录

使用Jupyter MCP Server

在正式使用前,你必须添加如下提示词于规则文件中以提供Jupyter MCP Server的必要连接信息:

以下是Jupyter服务器连接参数:
URL = http://localhost:8888
Token = YOUR_TOKEN

此外,推荐在提示词中添加关键Notebook路径信息,方便AI快速定位目标Notebook提高connect_notebook工具的执行效率,可以在Jupyter Lab网页中右键点击目标Notebook文件,选择Copy Path获取相对路径

在提供上述内容后,你就可以开始使用Jupyter MCP Server了!

✅ 最佳实践

  • 使用支持多模态输入的大模型(如Gemini 2.5 Pro)进行交互,以充分利用最先进的多模态理解能力
  • 使用支持MCP协议返回图像数据并支持解析的客户端(如Cursor、Gemini CLI等),部分客户端可能不支持该功能
  • 将复杂任务(如数据科学建模)拆分为多个子任务(如数据清洗、特征工程、模型训练、模型评估等),并逐步执行
  • 给出结构清晰的提示词与规则,这里可以参考提示词与规则文档
  • 在提示词中融入专家经验与智慧(如数据清洗、特征工程的技巧),这是AI最缺乏的,也是最需要补充的
  • 尽可能提供丰富的上下文信息(如现有数据集的字段解释,文件路径,详细的任务要求等)
  • 提供Few Shot案例,提供Baseline或已有Workflow作为参考

示例

🤝 贡献指南

我们欢迎社区贡献!如果您想为Jupyter MCP Server项目做出贡献,请:

  1. Fork 本仓库
  2. 创建您的特性分支 (git checkout -b feature/AmazingFeature)
  3. 提交您的更改 (git commit -m 'Add some AmazingFeature')
  4. 推送到分支 (git push origin feature/AmazingFeature)
  5. 开启一个 Pull Request

贡献类型

  • 🐛 Bug修复
  • 📝 旧功能完善
  • ✨ 新功能开发
  • 📚 文档改进
  • 🌍 国际化支持

开发帮助文档

🤗 致谢

本项目受到以下项目的帮助,在此表示感谢:

此外,本项目还参考了以下已有Jupyter MCP服务的实现,在此也一并表示感谢:


如果这个项目对您有帮助,请给我们一个 ⭐️

Made with ❤️ by ChengJiale150

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

better_jupyter_mcp_server-1.2.0.tar.gz (23.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

better_jupyter_mcp_server-1.2.0-py3-none-any.whl (16.9 kB view details)

Uploaded Python 3

File details

Details for the file better_jupyter_mcp_server-1.2.0.tar.gz.

File metadata

File hashes

Hashes for better_jupyter_mcp_server-1.2.0.tar.gz
Algorithm Hash digest
SHA256 56cc225ca08bbf6d0fb7d0fb54d0c073862fc62fbd44d0a9f9f5dfb71f92b65a
MD5 8a73832f9d91a8d228f496689c49a244
BLAKE2b-256 d6af7de3a97f8e26889cda9a8decb8b79589ed0d000e80384eb44f166364dc11

See more details on using hashes here.

File details

Details for the file better_jupyter_mcp_server-1.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for better_jupyter_mcp_server-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8df8a7a2e9e883152d695d343f26bee4d693d826b4af347e620600395d3b03d5
MD5 24c451393bd216dd2ef37a08feb0a7ed
BLAKE2b-256 8697ffa51fa35ce0d9b2624b2fa6518c2261edd27b6edec8a3d13fdfa6ac0d39

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page