Skip to main content

Command-line interface for running Stata commands via PyStata

Project description

stata-cli

License: MIT Python Version npm version

中文版 | English

A command-line interface for Stata via PyStata — built for humans and AI Agents. Run Stata code, .do files, view data, get help, and export graphs, all from the terminal. Includes a daemon mode for sub-second execution.

Install · AI Agent · Commands · Daemon · Advanced · Contributing

Why stata-cli?

  • Agent-Native Design — Structured JSON output, exit codes, and a SKILL.md definition out of the box — AI Agents can operate Stata with zero extra setup
  • Sub-Second Execution — Daemon mode keeps PyStata alive in the background, reducing startup from ~2-3s to ~85ms (35x speedup)
  • Full Coverage — Run code, execute .do files, view data, browse help, export graphs, interrupt execution — everything you need from one binary
  • AI-Friendly & Optimized — Compact output mode, token limit management, structured JSON responses, and graph auto-naming — designed for Agent tool-use
  • Open Source, Zero Barriers — MIT license, ready to use, just pip install
  • Up and Running in Seconds — Auto-detects your Stata installation, from install to first command in 2 steps

Features

Category Capabilities
Run Code Execute inline Stata code, multi-line blocks, or pipe from stdin
Do Files Run .do files with /// line continuation support and graph auto-naming
Data Viewer View current dataset as JSON with if-condition filtering and row limits
Help System Browse Stata help topics with SMCL-to-plain-text conversion
Graph Export Auto-detect and export graphs as PNG to ~/.stata-cli/graphs/
Daemon Mode Persistent background process for sub-second execution via Unix socket
Output Control Compact mode, JSON output, token limit management with full-output file save
Interruption Send break signal to stop long-running commands

Installation & Quick Start

Requirements

  • Stata 17+ installed on your machine (provides the PyStata library)
  • Python 3.9+

Quick Start (Human Users)

Install

Choose one of the following methods:

Option 1 — From pip (recommended):

pip install stata-cli

Option 2 — From npm / npx (zero Python setup):

# One-shot usage
npx stata-cli run "display 1+1"

# Global install
npm install -g stata-cli

The npm package is a thin wrapper that delegates to uvx, pipx, or python3.

Option 3 — From source:

git clone https://github.com/ashuiGordon/stata-cli.git
cd stata-cli
pip install -e ".[data]"

Use

# 1. Verify Stata is detected
stata-cli detect

# 2. Run your first command
stata-cli run "display 1+1"

# 3. Start daemon for fast execution
stata-cli daemon start
stata-cli run "sysuse auto, clear"    # ~85ms!

Quick Start (AI Agent)

The following steps are for AI Agents calling stata-cli via the Bash tool.

Step 1 — Install

pip install stata-cli

Step 2 — Verify Stata path

stata-cli detect

Step 3 — Start daemon (recommended)

stata-cli daemon start

Step 4 — Run commands

# Inline code
stata-cli run "sysuse auto, clear
regress price mpg weight
predict yhat"

# Structured JSON output
stata-cli --json run "summarize price"

# View data
stata-cli data --if "price>10000" --rows 50

# Lookup command syntax
stata-cli help regress

Commands

run — Execute Stata Code

stata-cli run "sysuse auto, clear"

# Multi-line
stata-cli run "sysuse auto, clear
summarize price mpg
regress price mpg weight"

# Pipe from stdin
echo "display 42" | stata-cli run -

do — Execute a .do File

stata-cli do analysis.do
stata-cli --compact do long_script.do

Do files are preprocessed: /// line continuations are joined, and unnamed graph commands are auto-named for reliable export.

data — View Current Dataset

stata-cli data
stata-cli data --if "price>5000" --rows 50

Returns the current dataset as JSON with columns, data, types, and row counts.

help — Browse Stata Help

stata-cli help regress
stata-cli help summarize

Displays help as plain text (SMCL markup is automatically converted).

stop — Interrupt Execution

stata-cli stop

Sends a break signal to the running Stata command (daemon mode).

detect — Find Stata Installation

stata-cli detect

Prints the auto-detected Stata installation path.

Daemon Mode

The daemon keeps PyStata alive in the background — reduces execution time from ~2-3s to ~85ms (35x speedup).

stata-cli daemon start       # Start background daemon
stata-cli run "display 1"    # Fast — auto-routes through daemon
stata-cli daemon status      # Check daemon state (PID, uptime, idle)
stata-cli daemon restart     # Clean restart (reset Stata state)
stata-cli daemon stop        # Shut down
Command Description
daemon start Start the background daemon process
daemon stop Graceful shutdown
daemon status Show PID, Stata path, uptime, idle time
daemon restart Stop + start (clean Stata state)

Commands auto-route through the daemon when it is running. Use --no-daemon to force direct execution.

The daemon auto-shuts down after 1 hour of inactivity (configurable with --idle-timeout).

Advanced Usage

Global Options

Option Description Default
--stata-path PATH Stata installation directory auto-detected
--edition [mp|se|be] Stata edition mp
--compact Strip verbose output noise off
--json Structured JSON output off
--timeout SECONDS Execution timeout 600
--max-tokens N Max output tokens (0=unlimited) 0
--no-daemon Force direct execution off
--graphs-dir PATH Graph export directory ~/.stata-cli/graphs/

JSON Output

stata-cli --json run "display 1+1"
{
  "success": true,
  "output": ". display 1+1\n2",
  "error": "",
  "execution_time": 0.04,
  "return_code": 0,
  "extra": {}
}
Field Type Description
success bool Whether the command succeeded
output string Stata output text
error string Error message (if any)
execution_time float Seconds elapsed
return_code int Stata r-code (0 = ok)
extra dict May contain graphs list with exported file paths

Graph Export

When Stata code creates graphs, they are automatically detected and exported as PNG:

stata-cli run "sysuse auto, clear
scatter price mpg"
[graph] graph1: /Users/you/.stata-cli/graphs/exec-.../graph1.png

In JSON mode, graph paths appear under extra.graphs.

Token Limit Management

For long outputs, use --max-tokens to truncate and save the full output to a file:

stata-cli --max-tokens 500 run "sysuse auto, clear
describe"

When output exceeds the limit, a preview is shown with a path to the full saved output.

Environment Variables

Variable Description
STATA_PATH Override Stata installation path
STATA_CLI_GRAPHS_DIR Override graph export directory

Exit Codes

Code Meaning
0 Success
1 Stata command error
2 CLI usage error
3 Stata not found / init failure

Agent Usage Pattern

# Full analysis workflow
stata-cli run "sysuse auto, clear
summarize price mpg
regress price mpg weight
predict yhat
list make price yhat in 1/5"

# Check data after loading
stata-cli data --if "price>10000"

# Lookup command syntax
stata-cli help anova

# Compact mode for less noise
stata-cli --compact run "sysuse auto, clear
describe"

# JSON mode for structured parsing
stata-cli --json run "display 1+1"

Contributing

Community contributions are welcome! If you find a bug or have feature suggestions, please submit an Issue or Pull Request.

For major changes, we recommend discussing with us first via an Issue.

License

This project is licensed under the MIT License.

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

stata_cli-0.2.1.tar.gz (23.3 kB view details)

Uploaded Source

Built Distribution

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

stata_cli-0.2.1-py3-none-any.whl (22.9 kB view details)

Uploaded Python 3

File details

Details for the file stata_cli-0.2.1.tar.gz.

File metadata

  • Download URL: stata_cli-0.2.1.tar.gz
  • Upload date:
  • Size: 23.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for stata_cli-0.2.1.tar.gz
Algorithm Hash digest
SHA256 fb9d807ca4653ba890086517f12bb4e7a387fdf134db81f7e3f604f5e175fc9e
MD5 ff9bae9b6522fc0fd8c6891f617aee04
BLAKE2b-256 10b7958e6dfc92ec0fb0f95140f5d55eff9ae7a0363798d9532f4708b882b257

See more details on using hashes here.

File details

Details for the file stata_cli-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: stata_cli-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 22.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for stata_cli-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b540aebde90bac914835fb6b8f4a895374633811b207c7cb2e04eecca0e20256
MD5 060fc24a5c03dccad2383e1ba6887aa2
BLAKE2b-256 49441ae9a07a040b91d6302bc7b11219c0ce8dc31d853ea2ce91517629d2b5ff

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