Skip to main content

MCP server for the Australian Bureau of Statistics Data API. Hides SDMX behind plain-English tools, with curated mappings for Labour Force, CPI, ERP, Building Approvals, and Lending Indicators.

Project description

abs-mcp

An MCP server that wraps the Australian Bureau of Statistics Data API and hides SDMX behind plain-English tools. Ask Claude "What's the unemployment rate in NSW?" and get a real answer with a source link, instead of a wall of SDMX codes.

Five tools, hand-curated mappings for Labour Force, CPI, Estimated Resident Population, Building Approvals, and Lending Indicators.

Install

# After publish:
uvx abs-mcp

# Local dev install:
uv pip install -e .

Claude Desktop

Add to ~/Library/Application Support/Claude/claude_desktop_config.json:

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

For a local checkout (before PyPI publish):

{
  "mcpServers": {
    "abs": {
      "command": "uv",
      "args": ["run", "--directory", "/absolute/path/to/abs-mcp", "abs-mcp"]
    }
  }
}

Restart Claude Desktop. The abs server appears in the tools panel with five tools.

Cursor

Add to ~/.cursor/mcp.json (or workspace .cursor/mcp.json):

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

Tools

Tool What it does
search_datasets(query, limit=10) Fuzzy-search ABS dataflow names. Returns the top matches.
describe_dataset(dataset_id) Plain-English description of a dataflow's dimensions and values.
get_data(dataset_id, filters, start_period, end_period, format) Query a dataflow with filters. Returns clean records (default), grouped series, or CSV.
latest(dataset_id, filters) Just the most recent observation(s) — wraps get_data with lastNObservations=1.
list_curated() The five dataflow IDs that have hand-curated plain-English support.

Curated dataflows

For these ten, filters accepts plain-English values (e.g. "region": "nsw" instead of "REGION": "1"):

  • LF — Labour Force, monthly: employment, unemployment, participation by state/sex
  • CPI — Consumer Price Index, quarterly inflation by capital city and category
  • WPI — Wage Price Index, quarterly wage growth by industry/sector/state
  • JV — Job Vacancies, quarterly labour demand by industry/sector/state
  • AWE — Average Weekly Earnings, half-yearly by industry/sector/state
  • ANA_AGG — National Accounts: GDP, GDP per capita, terms of trade, real income (Australia, quarterly)
  • ABS_ANNUAL_ERP_ASGS2021 — Estimated Resident Population, annual by state and sub-state geography
  • ERP_Q — Quarterly Estimated Resident Population, by state/sex/age
  • BA_GCCSA — Building Approvals, monthly by state/capital region and building type
  • LEND_HOUSING — Lending Indicators, quarterly housing finance commitments by purpose, lender, and state

Any other ABS dataflow still works — pass raw SDMX dimension IDs and codes.

Worked examples

"What's the current unemployment rate in NSW?"

Claude calls:

latest(dataset_id="LF", filters={"region": "nsw", "measure": "unemployment_rate"})

Returns:

{
  "dataset_id": "LF",
  "dataset_name": "Labour Force",
  "query": {"region": "nsw", "measure": "unemployment_rate"},
  "period": {"start": "2026-03", "end": "2026-03"},
  "records": [
    {
      "period": "2026-03",
      "value": 4.2,
      "dimensions": {"measure": "Unemployment rate", "region": "New South Wales", "sex": "Persons"}
    }
  ],
  "source": "Australian Bureau of Statistics",
  "abs_url": "https://www.abs.gov.au/statistics/labour/employment-and-unemployment/labour-force-australia"
}

"Show me NSW housing approvals over the last two years"

get_data(dataset_id="BA_GCCSA", filters={"region": "nsw", "measure": "dwelling_units"}, start_period="2024")

"Compare quarterly CPI in Sydney vs Melbourne"

get_data(dataset_id="CPI", filters={"region": ["sydney", "melbourne"], "measure": "change_year"}, start_period="2023")

Period formats

ABS uses different period formats per dataflow:

  • Monthly (LF, BA_GCCSA, LEND_HOUSING): "2026-03"
  • Quarterly (CPI): "2024-Q1"
  • Annual (ABS_ANNUAL_ERP_ASGS2021): "2024"

Pass start_period / end_period in the matching format.

Development

git clone https://github.com/Bigred97/abs-mcp.git
cd abs-mcp
uv sync --extra dev
uv pip install -e .

# Unit tests (no network)
uv run pytest

# Live integration tests (hits real ABS API)
uv run pytest -m live

The SQLite cache lives at ~/.abs-mcp/cache.db. Catalogue refreshes every 24h, codelists every 7 days, data responses every hour, latest 15 minutes. Delete the file to force a refresh.

How it differs from existing ABS MCP servers

The one existing community option (seansoreilly/abs) exposes a single query_dataset tool that passes raw SDMX through. This package offers semantic tools and curated mappings for the highest-value dataflows so an LLM can answer real questions without you needing to know what M13.3.1599.20.1.M means.

License

MIT — Harry Vass, 2026.

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

abs_mcp-0.2.0.tar.gz (239.4 kB view details)

Uploaded Source

Built Distribution

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

abs_mcp-0.2.0-py3-none-any.whl (28.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: abs_mcp-0.2.0.tar.gz
  • Upload date:
  • Size: 239.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.12 {"installer":{"name":"uv","version":"0.11.12","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 abs_mcp-0.2.0.tar.gz
Algorithm Hash digest
SHA256 a3827327a42508800606b98cd3947269fe435e1e5ad96c036108769ee832e899
MD5 0b855ad87033a9055c7208c013db086d
BLAKE2b-256 c02c71defb469761d661bc93140374150829c726a28c8808b8a684a2635c0fed

See more details on using hashes here.

File details

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

File metadata

  • Download URL: abs_mcp-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 28.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.12 {"installer":{"name":"uv","version":"0.11.12","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 abs_mcp-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 dfdf8d545a79afc6a97daa595ffa19e2ce407f693d82e7ad2b381b5fa924ba22
MD5 600015aa126d80709aaf3bd44e06c6d5
BLAKE2b-256 1b0ee48a89ece76adc5bc0764acd0c7671f83575f69b91246404763b7c395075

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