Skip to main content

A Stata integration server based on Model Context Protocol (MCP) that allows AI assistants to execute Stata scripts, fetch data information, and run statistical analysis.

Project description

aigroup-stata-mcp

Python 3.11+ License: MIT MCP Protocol PyPI version

一个基于 Model Context Protocol (MCP) 的 Stata 集成服务器,允许 AI 助手执行 Stata 脚本、获取数据信息和运行统计分析。

功能特性

🚀 核心功能

  • Stata 脚本执行: 执行 .do 文件并捕获日志输出
  • 数据信息获取: 支持 .dta.csv 文件的描述性统计
  • Stata 命令帮助: 获取 Stata 内置命令的帮助文档
  • SSC 包管理: 从 SSC 仓库安装和管理 Stata 包
  • 文件操作: 创建、读取和写入 Stata 脚本文件

🔧 技术特性

  • 跨平台支持: Windows、macOS 和 Linux
  • 自动 Stata 检测: 自动查找系统上的 Stata 安装路径
  • 多传输协议: 支持 stdio、SSE、HTTP 和 streamable-http
  • 结构化输出: 使用 Pydantic 模型提供类型安全的响应
  • 多语言支持: 中英文界面和提示
  • 配置管理: 支持 TOML 格式的配置文件

📊 数据处理

  • 数据格式支持: Stata (.dta)、CSV (.csv) 文件
  • 统计分析: 描述性统计、变量分析
  • URL 数据源: 支持从 URL 直接读取数据文件
  • 智能编码检测: 自动检测文件编码和分隔符

快速开始

系统要求

  • Python: 3.11 或更高版本
  • Stata: 已安装并配置好环境变量
  • MCP 客户端: Claude Desktop、通义灵码、roocode、Cherry Studio 或其他兼容 MCP 的客户端

安装

# 使用 pip 安装
pip install aigroup-stata-mcp

# 或使用 uv 安装
uv add aigroup-stata-mcp

# 或使用 uvx 直接运行(无需安装)
uvx aigroup-stata-mcp

配置

配置文件

Stata-MCP 支持使用 TOML 格式的配置文件。配置文件位于项目根目录的 config.toml

示例配置文件:

name = "aigroup-stata-mcp"
instructions = "Stata-MCP lets you and LLMs run Stata do-files and fetch results"
website_url = "https://github.com/jackdark425"

# Working directory for the server
# If not specified, will use default based on OS:
# - Linux/macOS: ~/Documents
# - Windows: %USERPROFILE%\Documents
# working_directory = "/path/to/working/directory"

# Path to Stata CLI executable
# If not specified, will auto-detect
# stata_cli = "/usr/local/stata/stata-mp"

你也可以通过 --config 参数指定自定义配置文件路径。

MCP 客户端配置

在支持 MCP 协议的 AI 客户端配置文件中添加以下内容:

通用配置格式:

{
  "mcpServers": {
    "stata-mcp": {
      "command": "uvx",
      "args": ["aigroup-stata-mcp"]
    }
  }
}

注意: 系统会自动识别 Stata 安装路径,通常无需手动配置。如果自动识别失败,可以通过设置 STATA_CLI 环境变量指定 Stata 可执行文件路径。

不同客户端的配置文件位置可能不同,以下是一些常见客户端的配置文件位置:

  • Claude Desktop:
    • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
    • Windows: %APPDATA%\Claude\claude_desktop_config.json

使用安装器

项目提供了自动安装工具:

# 检查系统兼容性
stata-mcp --usable

# 自动安装到 Claude Desktop
stata-mcp --install

可用工具

Stata 工具

stata_do

执行 Stata do 文件并返回执行结果。

参数:

  • dofile_path: do 文件路径
  • log_file_name: 日志文件名(可选)
  • is_read_log: 是否读取日志内容(默认: true)

示例:

regress price mpg weight
outreg2 using "results", replace

get_data_info

获取数据文件的描述性统计信息。

参数:

  • data_path: 数据文件路径
  • vars_list: 变量列表(可选)
  • encoding: 文件编码(默认: utf-8)
  • file_extension: 文件扩展名(可选)
  • is_save: 是否保存结果到文件(默认: true)

支持格式:

  • Stata 文件 (.dta)
  • CSV 文件 (.csv, .txt, .tsv)

help

获取 Stata 命令的帮助文档。

参数:

  • cmd: Stata 命令名称

示例:

help regress
help summarize

ssc_install

从 SSC 仓库安装 Stata 包。

参数:

  • command: 包名称
  • is_replace: 是否替换已安装版本(默认: true)

文件工具

write_dofile

创建新的 Stata do 文件。

参数:

  • content: Stata 代码内容
  • encoding: 文件编码(默认: utf-8)

append_dofile

向现有 do 文件追加内容或创建新文件。

参数:

  • original_dofile_path: 原始 do 文件路径
  • content: 要追加的 Stata 代码
  • encoding: 文件编码(默认: utf-8)

read_file

读取文件内容。

参数:

  • file_path: 文件路径
  • encoding: 文件编码(默认: utf-8)

load_figure

加载图片文件。

参数:

  • figure_path: 图片文件路径(支持 png、jpg 格式)

核心工具

mk_dir

安全创建目录。

参数:

  • path: 目录路径

可用提示

stata_assistant_role

获取 Stata 助手角色定义提示。

参数:

  • lang: 语言代码(en/cn,可选)

stata_analysis_strategy

获取 Stata 分析策略指南。

参数:

  • lang: 语言代码(en/cn,可选)

results_doc_path

生成结果文档存储路径。

项目结构

stata_mcp/
├── core/                    # 核心功能模块
│   ├── data_info/          # 数据信息处理
│   │   ├── _base.py        # 数据信息基类
│   │   ├── dta.py          # Stata 文件处理
│   │   └── csv.py          # CSV 文件处理
│   └── stata/              # Stata 集成
│       ├── stata_controller/ # Stata 会话控制
│       ├── stata_do/       # do 文件执行器
│       └── stata_finder/   # Stata 路径查找器
├── server/                 # MCP 服务器实现
│   ├── tools/              # MCP 工具定义
│   │   ├── core_tools.py   # 核心工具
│   │   ├── file_tools.py   # 文件工具
│   │   └── stata_tools.py  # Stata 工具
│   ├── prompts/            # MCP 提示定义
│   └── main.py             # 服务器主程序
├── utils/                  # 工具类
│   ├── Installer/          # 安装器
│   ├── Prompt/             # 提示管理
│   └── usable.py           # 系统兼容性检查
└── cli/                    # 命令行接口

开发指南

环境设置

  1. 克隆仓库:
git clone https://github.com/jackdark425/aigroup-stata-mcp.git
cd aigroup-stata-mcp
  1. 安装开发依赖:
pip install -e ".[dev]"
  1. 运行测试:
python -m pytest

添加新工具

src/stata_mcp/server/tools/ 目录下创建新的工具文件:

from mcp.server.fastmcp import Context, FastMCP
from pydantic import BaseModel, Field

class MyToolResult(BaseModel):
    result: str = Field(description="Tool execution result")

def register_my_tools(server: FastMCP) -> None:
    @server.tool()
    def my_tool(ctx: Context, param: str) -> MyToolResult:
        """Tool description."""
        # Tool implementation
        return MyToolResult(result="Success")

然后在 src/stata_mcp/server/main.py 中注册新工具。

故障排除

常见问题

  1. Stata 未找到

    • 确保 Stata 已正确安装
    • 手动设置 STATA_CLI 环境变量
    • 使用 stata-mcp --usable 检查配置
  2. 权限错误

    • 确保对工作目录有读写权限
    • 检查防火墙设置
  3. 编码问题

    • 指定正确的文件编码
    • 使用 UTF-8 编码处理中文数据

调试模式

启用详细日志输出:

stata-mcp --verbose

贡献指南

我们欢迎贡献!请参阅 CONTRIBUTING.md 了解详细信息。

  1. Fork 项目
  2. 创建功能分支 (git checkout -b feature/AmazingFeature)
  3. 提交更改 (git commit -m 'Add some AmazingFeature')
  4. 推送到分支 (git push origin feature/AmazingFeature)
  5. 打开 Pull Request

许可证

本项目基于 MIT 许可证 - 查看 LICENSE 文件了解详细信息。

致谢

支持

如果您遇到问题或有建议,请:

  1. 查看 问题页面
  2. 创建新的 issue
  3. 联系维护者: jackdark425@gmail.com

注意: 本项目与 StataCorp LLC 无关,Stata 是 StataCorp LLC 的注册商标。

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

aigroup_stata_mcp-1.0.9.tar.gz (35.5 kB view details)

Uploaded Source

Built Distribution

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

aigroup_stata_mcp-1.0.9-py3-none-any.whl (50.2 kB view details)

Uploaded Python 3

File details

Details for the file aigroup_stata_mcp-1.0.9.tar.gz.

File metadata

  • Download URL: aigroup_stata_mcp-1.0.9.tar.gz
  • Upload date:
  • Size: 35.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for aigroup_stata_mcp-1.0.9.tar.gz
Algorithm Hash digest
SHA256 e353dd54724fcb8a009fa28ce5c80cf9fb66659398b02e09f53db106d188d0c9
MD5 12de039c1ed6566a6c96dddafcf2f25f
BLAKE2b-256 4b4f431101f3f36de8674ad2de84655e59c710e2a89f8accf5119a32a27c7aed

See more details on using hashes here.

File details

Details for the file aigroup_stata_mcp-1.0.9-py3-none-any.whl.

File metadata

File hashes

Hashes for aigroup_stata_mcp-1.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 e9e104d6158a138208ccf42975bd138cfe8a5e709ba34ac1eb4fa1958d0df3ea
MD5 fdef212a0d8418d710ae7952baad41c6
BLAKE2b-256 b124166bdee9f5a6bc25c09c65b9e66ea6109a2afbc08d5e903846c277ef69d5

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