Skip to main content

Jupyter code executor mcp server

Project description

Jupyter Code Executor MCP Server

Python >= 3.11 License: MIT MCP

A powerful Model Context Protocol (MCP) server that enables AI assistants to execute code in multiple programming languages through Jupyter kernels. This server provides stateful and stateless code execution capabilities with session management, automatic cleanup, and comprehensive data analysis tools.

✨ Key Features

🚀 Multi-Language Code Execution

  • Universal Kernel Support: Execute code in any language with an installed Jupyter kernel (Python, R, Julia, etc.)
  • Dual Execution Modes:
    • Stateful Sessions: Maintain variable context across multiple executions within the same session
    • Stateless Execution: One-off code execution without persistent context

🎯 Built-in Data Analysis Capabilities

  • Pre-configured Environment: Includes essential data science libraries (Pandas, NumPy, Scikit-learn, Seaborn, etc.)
  • Expert Prompt Templates: Built-in data analyst prompt with best practices for EDA, ML, and visualization
  • Professional Visualizations: Seaborn and Matplotlib integration for publication-quality charts

📋 Prerequisites

  • Python: >= 3.11
  • uv: Modern Python package installer (recommended)
  • Jupyter: Jupyter kernels for your target languages

🔧 Installation

Using uv (Recommended)

# Install the package
uv pip install jupyter-code-executor-mcp-server

# Or install from source
git clone https://github.com/twn39/jupyter-code-executor-mcp-server.git
cd jupyter-code-executor-mcp-server
uv sync
uv run jupyter-code-executor-mcp-server

Using pip

pip install jupyter-code-executor-mcp-server

🚀 Quick Start

Starting the Server

# Start with default settings
uv run jupyter-code-executor-mcp-server

# Start with custom configuration
uv run jupyter-code-executor-mcp-server \
  --port 8080 \
  --data_dir ~/my-data \
  --output_dir ~/my-output \
  --session-timeout 1200

Command Line Options

Option Short Description Default
--transport -t Server transport protocol streamable-http
--port -p Server listening port 5010
--data_dir -d User data directory ~/data
--output_dir -o Code output directory ~/output
--session-timeout -st Session timeout (seconds) 600

Testing the Server

Use the MCP Inspector to interact with the server:

pnpx @modelcontextprotocol/inspector

📚 Available MCP Tools

1. list_kernels

List all installed and available Jupyter kernels on your system.

Returns: String containing kernel names and display names

Example Response:

Available Jupyter Kernels:
Format: [Kernel Name] - [Display Name]
----------------------------------------
- python3: Python 3
- ir: R
- julia-1.9: Julia 1.9

2. execute_code

Execute code in a specified Jupyter kernel with optional session persistence.

Parameters:

  • code (string): The code to execute
  • kernel_name (string): Target kernel name (use list_kernels to find available kernels)
  • session_id (string, optional): Session identifier for stateful execution

Returns: Execution result including kernel name, exit code, and output

Stateless Example (Python):

# Execute code without session persistence
code = """
import pandas as pd
df = pd.DataFrame({'A': [1, 2, 3], 'B': [4, 5, 6]})
print(df.describe())
"""

Stateful Example (Python with session):

# First execution - create variables
session_id = "data-analysis-001"
code1 = """
import pandas as pd
df = pd.DataFrame({'A': [1, 2, 3], 'B': [4, 5, 6]})
"""

# Second execution - reuse variables from session
code2 = """
# df is still available from previous execution
print(df.describe())
print(f"Shape: {df.shape}")
"""

R Example:

# Execute R code
code = """
data <- data.frame(x = 1:10, y = rnorm(10))
summary(data)
plot(data$x, data$y)
"""
kernel_name = "ir"

📖 Available Prompts

data_analyst_prompt

A comprehensive prompt template for AI-powered data analysis featuring:

  • Statistical Analysis: EDA, hypothesis testing, attribution analysis, time series
  • Machine Learning: Supervised/unsupervised learning, model evaluation, hyperparameter tuning
  • Deep Learning: Neural networks, CNNs, RNNs/LSTMs with TensorFlow/PyTorch
  • Professional Visualization: Publication-quality charts with Seaborn/Matplotlib
  • Iterative Workflow: Think → Act → Observe → Interpret cycle

This prompt transforms your AI assistant into an expert data scientist with code execution capabilities.

🤝 Contributing

Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.

Development Setup

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add some amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

📄 License

This project is licensed under the MIT License - see the LICENSE file for details.

🙏 Acknowledgments


Note: This server requires properly configured Jupyter kernels for the languages you want to execute. Install kernels using commands like pip install ipykernel (Python), install.packages('IRkernel') (R), or following the respective kernel installation guides.

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

jupyter_code_executor_mcp_server-0.2.0.tar.gz (10.6 kB view details)

Uploaded Source

Built Distribution

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

File details

Details for the file jupyter_code_executor_mcp_server-0.2.0.tar.gz.

File metadata

  • Download URL: jupyter_code_executor_mcp_server-0.2.0.tar.gz
  • Upload date:
  • Size: 10.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.17 {"installer":{"name":"uv","version":"0.9.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for jupyter_code_executor_mcp_server-0.2.0.tar.gz
Algorithm Hash digest
SHA256 9647e37ed3cec21e18aac7f8982260e623eced6a2c979cde08676e902cd103e3
MD5 66471e0596524bef683bee40eb5ad0a5
BLAKE2b-256 2c42c734f7ffc7aa7164272df6ab30b8d899eae91879b53fb51783ef93b6c78e

See more details on using hashes here.

File details

Details for the file jupyter_code_executor_mcp_server-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: jupyter_code_executor_mcp_server-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 12.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.17 {"installer":{"name":"uv","version":"0.9.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for jupyter_code_executor_mcp_server-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e34a20f17f245b98c8fa74a06250afe2a5cb403e61ceb7cd9b4d4f5392fa8f53
MD5 4f3266d43176020ac3ef513e8974ea13
BLAKE2b-256 36912ac0f581318145e76bbc1eb5a944120310dfd8ed13fb22ee31f56f711834

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