python-repl-mcp

python-repl-mcp

一个基于MCP的Python REPL服务器,支持多会话管理、代码执行、历史记录回放和包安装,为AI提供Python解释器能力。

Category
访问服务器

README

python-repl-mcp

一个基于 Model Context Protocol (MCP) 的 Python REPL 服务器,支持多会话管理、代码执行、历史记录回放和包安装。给 AI 装上一个 Python 解释器,配合任意 Python 库即可扩展无限能力。

功能特性

  • 多会话管理 - 创建、列出、重置、删除独立的 Python 执行会话
  • 代码执行 - 在指定会话中执行 Python 代码,自动捕获 stdout/stderr
  • 文件执行 - 直接在会话中执行 Python 文件,自动处理 sys.path 和 __file__
  • 表达式求值 - 自动检测最后一条语句是否为表达式并返回其值(类似 IPython)
  • 超时控制 - 代码执行默认不超时,可设置 timeout 参数限制执行时间
  • 工作目录 - 创建会话时可指定 cwd 和 sys_paths
  • 执行历史 - 交互式 REPL 风格输出(>>> 格式),支持查看最近 N 条或全部
  • 历史回放 - 从历史记录中提取代码重新执行
  • 脚本导出 - 将历史代码保存为 .py 文件
  • 运行时重置 - 深度重置会话(卸载导入的模块、恢复 sys.path)
  • 包安装 - 通过 pip 安装 Python 包
  • 多通信方式 - 通过环境变量切换 stdio / SSE / Streamable HTTP 传输

安装

pip install python-repl-mcp

MCP 配置

.kiro/settings/mcp.json~/.kiro/settings/mcp.json 中添加:

使用 Python 启动(推荐)

直接运行在当前 Python 环境中,可以访问本机已安装的所有包。

{
  "mcpServers": {
    "python-repl": {
      "command": "python",
      "args": ["-m", "python_repl_mcp"],
      "disabled": false
    }
  }
}

使用 uvx 启动

无需预先安装,uvx 会自动下载并运行。但注意 uvx 会创建临时隔离的虚拟环境,本机已安装的库在其中不可用,需通过 install_package 工具重新安装。

{
  "mcpServers": {
    "python-repl": {
      "command": "uvx",
      "args": ["python-repl-mcp"],
      "disabled": false
    }
  }
}

环境变量

变量名 说明 可选值 默认值
MCP_TRANSPORT MCP 通信方式 stdio, sse, streamable-http stdio
MCP_HOST HTTP 模式绑定地址 任意 IP 地址 127.0.0.1
MCP_PORT HTTP 模式绑定端口 任意端口号 8000

MCP_HOSTMCP_PORT 仅在 MCP_TRANSPORTssestreamable-http 时生效。

示例:使用 SSE 模式

{
  "mcpServers": {
    "python-repl": {
      "command": "python",
      "args": ["-m", "python_repl_mcp"],
      "env": {
        "MCP_TRANSPORT": "sse",
        "MCP_HOST": "0.0.0.0",
        "MCP_PORT": "8080"
      },
      "disabled": false
    }
  }
}

示例:使用 Streamable HTTP 模式

MCP_TRANSPORT=streamable-http MCP_HOST=0.0.0.0 MCP_PORT=9000 python -m python_repl_mcp

工具列表

create_session

创建一个新的 Python REPL 会话。

参数 类型 必填 说明
session_id string 自定义会话ID,不提供则自动生成
cwd string 工作目录,执行代码时自动切换,同时加入 sys.path
sys_paths list[string] 额外的包搜索路径列表

list_sessions

列出所有活跃的会话及其元数据,包括 cwd、sys_paths、history_count、variable_count 等。

reset_session

重置会话的命名空间和执行历史,会话本身保留。

参数 类型 必填 说明
session_id string 要重置的会话ID

reset_run_context

深度重置:卸载会话中导入的模块、恢复 sys.path、清空命名空间(保留历史记录)。

参数 类型 必填 说明
session_id string 要重置的会话ID

delete_session

永久删除一个会话及其所有数据。

参数 类型 必填 说明
session_id string 要删除的会话ID

run_code

在指定会话中执行 Python 代码。支持两种模式:直接提供代码,或从历史记录中提取代码执行。

参数 类型 必填 说明
session_id string 执行代码的会话ID
code string 要执行的 Python 代码(不提供则从历史中提取)
start_line integer 起始行号(1-based),用于切片代码或索引历史
end_line integer 结束行号(1-based, inclusive)
timeout integer 执行超时秒数,默认 None(不超时),设置正数限制执行时间

get_history

获取会话的执行历史,以交互式 Python REPL 格式输出。

参数 类型 必填 说明
session_id string 要查看的会话ID
n integer 返回最近 N 条记录,不传则返回全部

输出示例:

[1] >>> a = 1
[2] >>> a
1
[3] >>> b
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
NameError: name 'b' is not defined

delete_history

删除指定范围的历史记录。

参数 类型 必填 说明
session_id string 会话ID
start_line integer 起始记录索引(1-based, inclusive)
end_line integer 结束记录索引(1-based, inclusive),默认等于 start_line

save_script

将历史代码导出为 Python 脚本文件。

参数 类型 必填 说明
session_id string 会话ID
path string 保存路径(如 'output.py')
start_line integer 起始记录索引,默认 1
end_line integer 结束记录索引,默认最后一条

run_file

在指定会话中执行一个 Python 文件。文件内容在会话的命名空间中执行,执行期间文件所在目录会临时加入 sys.path。

参数 类型 必填 说明
session_id string 执行文件的会话ID
path string Python 文件路径
timeout integer 执行超时秒数,默认不超时

install_package

通过 pip 安装 Python 包到当前环境,安装后所有会话可用。

参数 类型 必填 说明
package_name string 包名(如 'numpy', 'pandas==2.0.0')

使用示例

1. create_session(session_id="demo", cwd="/my/project")

2. run_code(session_id="demo", code="import math\nresult = math.sqrt(144)\nresult")
   → [1] >>> import math
          ... result = math.sqrt(144)
          ... result
     12.0

3. run_code(session_id="demo", code="result + 1")
   → [2] >>> result + 1
     13.0

4. run_file(session_id="demo", path="/my/project/utils.py")
   → [3] >>> exec('utils.py')
     Loaded 5 utility functions.

5. run_code(session_id="demo", code="my_util_func(42)")
   → [4] >>> my_util_func(42)
     84

6. get_history(session_id="demo")
   → [1] >>> import math
          ... result = math.sqrt(144)
          ... result
     12.0

     [2] >>> result + 1
     13.0

     [3] >>> exec('utils.py')
     Loaded 5 utility functions.

     [4] >>> my_util_func(42)
     84

7. save_script(session_id="demo", path="demo.py")
   → Script saved to 'demo.py'

8. reset_run_context(session_id="demo")  # 深度重置,保留历史
9. delete_session(session_id="demo")

项目结构

python-repl-mcp/
├── pyproject.toml
├── README.md
└── python_repl_mcp/
    ├── __init__.py
    └── server.py      # 单文件实现:会话管理、代码执行、MCP工具

开发

# 克隆项目
git clone https://github.com/miloira/python-repl-mcp.git
cd python-repl-mcp

# 开发模式安装
pip install -e .

# 运行服务器
python -m python_repl_mcp

发布

pip install build twine
python -m build
twine upload dist/*

设计理念

相比传统的固定 Skill/Tool,python-repl-mcp 的优势在于:

  • 万能扩展pip install 任意库 + 丢一份文档 = 新能力上线
  • 零开发成本 — 不需要写 tool schema,Python 能做的事它都能做
  • 有状态交互 — 变量持久化,像真的在写代码一样逐步探索
  • 灵活组合 — 一段代码搞定复杂编排,无需多个 tool 串联

推荐服务器

Baidu Map

Baidu Map

百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。

官方
精选
JavaScript
Playwright MCP Server

Playwright MCP Server

一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。

官方
精选
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。

官方
精选
本地
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。

官方
精选
本地
TypeScript
VeyraX

VeyraX

一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。

官方
精选
本地
graphlit-mcp-server

graphlit-mcp-server

模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。

官方
精选
TypeScript
Kagi MCP Server

Kagi MCP Server

一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。

官方
精选
Python
e2b-mcp-server

e2b-mcp-server

使用 MCP 通过 e2b 运行代码。

官方
精选
Neon MCP Server

Neon MCP Server

用于与 Neon 管理 API 和数据库交互的 MCP 服务器

官方
精选
Exa MCP Server

Exa MCP Server

模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。

官方
精选