loading…
Search for a command to run...
loading…
Enables AI agents to directly manipulate Jupyter Notebook cells and structure through a secure, well-defined API, overcoming Cursor's AI agent mode limitations.
Enables AI agents to directly manipulate Jupyter Notebook cells and structure through a secure, well-defined API, overcoming Cursor's AI agent mode limitations.
PyPI Version PyPI - Downloads Total Downloads License Python Version GitHub issues Last Commit Coverage Status
A Model Context Protocol (MCP) server that enables AI agents to interact with Jupyter Notebook (.ipynb) files. Designed to overcome limitations with Cursor's AI agent mode, this tool allows AI assistants to directly manipulate notebook cells and structure through a secure, well-defined API.
Current Version: 0.9.0 - See the CHANGELOG.md for details on recent changes.
Although originally designed for Cursor, this MCP server can be used with any MCP-compatible AI assistant tool, such as Claude Code.
# Run (minimal example)
uvx the-notebook-mcp --allow-root /path/to/your/notebooks
# Too see command options...
uvx the-notebook-mcp help
Cursor Jupyter Notebook MCP Server Tutorial demonstrates:
The server provides the following MCP tools:
notebook_create: Creates a new, empty notebook filenotebook_delete: Deletes an existing notebook filenotebook_rename: Renames/moves a notebook file from one path to anothernotebook_export: Exports the notebook to another format (python, html, etc.)notebook_validate: Validates the notebook structure against the nbformat schemanotebook_read: Reads an entire notebook and returns its structure as a dictionarynotebook_read_cell: Reads the source content of a specific cellnotebook_get_cell_count: Returns the total number of cellsnotebook_get_info: Retrieves general information about the notebooknotebook_get_outline: Generates a structural outline of the notebook (headings, definitions)notebook_search: Searches for a string within all notebook cellsnotebook_add_cell: Adds a new code or markdown cellnotebook_edit_cell: Replaces the source content of a specific cellnotebook_delete_cell: Deletes a specific cellnotebook_move_cell: Moves a cell to a different positionnotebook_change_cell_type: Changes a cell's type (code, markdown, or raw)notebook_duplicate_cell: Duplicates a cell multiple timesnotebook_split_cell: Splits a cell into two at a specified line numbernotebook_merge_cells: Merges a cell with the one immediately following itnotebook_execute_cell: Executes a code cell and returns its outputsnotebook_execute_cell('/path/to/notebook.ipynb', 1, server_url='http://localhost:8888', token='your-token')notebook_read_metadata: Reads the top-level notebook metadatanotebook_edit_metadata: Updates the top-level notebook metadatanotebook_read_cell_metadata: Reads the metadata of a specific cellnotebook_edit_cell_metadata: Updates the metadata of a specific cellnotebook_read_cell_output: Reads the output list of a specific code cellnotebook_clear_cell_outputs: Clears the outputs and execution count of a specific cellnotebook_clear_all_outputs: Clears outputs and execution counts for all code cellsPython Version: ≥ 3.10
Core Dependencies: (automatically installed)
fastmcp ≥ 2.3.3nbformat ≥ 5.0nbconvert ≥ 6.0ipythonjupyter_coreloguru ≥ 0.7.3SSE Transport: (install with uv pip install "the-notebook-mcp[sse]")
uvicorn ≥ 0.20.0starlette ≥ 0.25.0For exporting to certain formats, you may need:
You can run the server directly with
uvx the-notebook-mcp --allow-root $PWD
But if you prefer to install it...
# Basic installation (stdio transport only)
uv tool install the-notebook-mcp
# Using pip
pip install the-notebook-mcp
Clone the repository:
git clone https://github.com/svallory/the-notebook-mcp.git
cd the-notebook-mcp
Create and activate a virtual environment:
uv venv
source .venv/bin/activate # On Windows use `.venv\Scripts\activate`
Install in development mode:
uv pip install -e ".[dev]"
Set up pre-commit hooks (recommended):
pre-commit install
See Pre-commit Hook Setup for details.
# stdio transport (default)
the-notebook-mcp --allow-root /path/to/notebooks
# SSE transport
the-notebook-mcp --transport sse --allow-root /path/to/notebooks --host 0.0.0.0 --port 8889
Use one of these methods when working with the source code:
# Using poethepoet tasks
uv run poe start
# Using the Python module
python -m the_notebook_mcp.server --allow-root /path/to/notebooks
The project includes these predefined tasks:
start: Start the server with default settingscheck-help: Show help informationcheck-version: Show version informationtest: Run the test suiteExample:
# Show help
uv run poe check-help
# Run tests
uv run poe test
--allow-root: (Required) Path to a directory where notebooks are allowed (can be used multiple times)--transport: stdio (default) or sse--host: Host for SSE transport (default: 0.0.0.0)--port: Port for SSE transport (default: 8889)--max-cell-source-size: Maximum bytes for cell source (default: 10MB)--max-cell-output-size: Maximum bytes for cell output (default: 10MB)--log-dir: Directory for log files (default: ~/.the_notebook_mcp)--log-level: DEBUG, INFO (default), WARNING, ERROR, CRITICALTo configure Cursor to use this server, add settings to ~/.cursor/mcp.json (global) or .cursor/mcp.json (project-specific).
[!IMPORTANT] Cursor will expand the
"."argument, but it does not expand"./some/folder".
{
"mcpServers": {
"the-notebook-mcp": {
"command": "uvx",
"args": [
"the-notebook-mcp",
"start",
"--allow-root",
"."
]
}
}
}
{
"mcpServers": {
"the-notebook-mcp": {
"command": "the-notebook-mcp",
"args": [
"start",
"--allow-root",
"."
]
}
}
}
[!NOTE] You'll need to run the server separately
{
"mcpServers": {
"notebook_mcp": {
"url": "http://127.0.0.1:8889/sse"
}
}
}
# Setup
uv venv
source .venv/bin/activate
uv pip install -e ".[dev]"
pre-commit install
# Testing
uv run poe test
Contributions are welcome! Please:
See GitHub Issues for existing bugs or feature requests.
This project is based on the work of Jim Beno in cursor-notebook-mcp.
This project is licensed under the MIT License. See the LICENSE file for details.
Maintained by Saulo Vallory.
Выполни в терминале:
claude mcp add the-notebook-mcp -- npx Безопасность
Низкий рискАвтоматическая эвристика по публичным данным — не гарантия безопасности.