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.3.0.tar.gz (12.0 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.3.0.tar.gz.

File metadata

  • Download URL: jupyter_code_executor_mcp_server-0.3.0.tar.gz
  • Upload date:
  • Size: 12.0 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.3.0.tar.gz
Algorithm Hash digest
SHA256 aac409a9385a7d7a7948ef44e6829e343c7490093d0824bb9a9577ddc1604304
MD5 72f42cdff386db396a4d85f31283c182
BLAKE2b-256 c31e52b2d7b7f5520c3d04fe8bd17bf02fa594a63e45766920740ad960dd83f5

See more details on using hashes here.

File details

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

File metadata

  • Download URL: jupyter_code_executor_mcp_server-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 14.3 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.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 70b5bb78dccec9d5249a94110c1bd4261102cba6eabbb4ef27b4aab9b51f3afb
MD5 b1f4c8312c6d340f000ea3f04a22bed7
BLAKE2b-256 2710404797a6ba1c3387f93e02f3f15856e07b064ece531425b13959c70455e8

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