MCP server for U.S. Census (ACS) data by ZIP code — income, age, housing, education — served from a local store. Needs a free Census API key.
Project description
census-mcp
U.S. Census data by ZIP code, inside your agent. An MCP
server that lets an LLM look up income, demographics, housing, and education for any ZIP —
built on Anthropic's official mcp Python SDK.
All tools are read-only. Data is the U.S. Census Bureau's American Community Survey (ACS) 5-year release — bulk-downloaded once into a local store, then served offline. A free Census API key is required for the one-time download.
Status: all 8 tools below are live and unit-tested, and the server has been verified end-to-end against the live ACS 5-year release (vintage 2024 at the time of writing — the server auto-detects the latest). PyPI + MCP Registry publish is the next step. Part of the mcpwright suite.
Tools
| Tool | What it does |
|---|---|
lookup_zip(zip_code) |
Confirm a ZIP maps to a Census ZCTA; returns name, total population, and the ACS vintage. |
get_income(zip_code) |
Median household income, per-capita income, total households, and the % of households earning $200k+. |
get_demographics(zip_code) |
Total population and median age. |
get_housing(zip_code) |
Median home value, median gross rent, occupied units, and % owner-occupied. |
get_education(zip_code) |
Of adults 25+, the % with a bachelor's degree or higher and the % with a graduate/professional degree. |
compare_zips(zips, metric) |
Rank several ZIPs by one metric (income, age, home value, attainment, …), highest first. |
get_acs_variable(zip_code, variable) |
Escape hatch: the raw value of any stored ACS variable, by code or friendly name. |
find_zips(place, state=None) |
Reverse lookup: the ZIPs that fall within a city/town/CDP, ranked by how much of each ZIP's land lies in the place. |
ZIP ≈ ZCTA (ZIP Code Tabulation Area): they mostly coincide, but ~2% of ZIPs (PO-box-only / non-residential) have no ZCTA and will return an error. All ACS figures are 5-year estimates.
find_zips is the reverse direction (place → ZIPs). It's approximate: ZCTAs don't nest inside
places, so a ZIP can span several places and vice versa — read each match's coverage_pct and
pass a state to disambiguate same-named places (e.g. Cambridge, MA vs OH). It's built on the
public 2020 Census ZCTA-to-Place relationship file (2020 geography; no API key needed for it).
Install
Requires Python 3.12+ and a free Census API key
(set CENSUS_API_KEY). The PyPI package is mcpwright-census; the command, server, and tools
are all "census".
export CENSUS_API_KEY=your-free-key
uvx mcpwright-census setup # one-time: bulk-download the ACS dataset into a local store
Claude Code
claude mcp add census -e CENSUS_API_KEY=your-free-key -- uvx mcpwright-census
Claude Desktop
Add to claude_desktop_config.json:
{
"mcpServers": {
"census": {
"command": "uvx",
"args": ["mcpwright-census"],
"env": { "CENSUS_API_KEY": "your-free-key" }
}
}
}
First run downloads the full ACS dataset (~33k ZCTAs) into a local SQLite store under your OS cache dir, so every later lookup is instant and offline. Run
mcpwright-census setupahead of time, or let the server download lazily on first use.mcpwright-census refreshre-pulls when a new ACS vintage is published. Override the store location withCENSUS_MCP_STORE.
Develop
git clone https://github.com/mcpwright/census-mcp && cd census-mcp
uv sync
uv run pytest -v # tests (mocked Census + seeded SQLite)
uv run ruff check src/ && uv run ruff format --check src/ # lint + format
uv run mypy # type checking
uv run mcp dev src/census_mcp/server.py # poke the tools in the MCP Inspector
Roadmap
-
lookup_zip— validate a ZIP, name + population -
get_income— income measures + % $200k+ -
get_demographics— population + median age (age brackets still to come) -
get_housing— median home value, rent, % owner-occupied -
get_education— % bachelor's+, % graduate -
compare_zips— one metric across several ZIPs, ranked -
get_acs_variable— raw value for any stored ACS variable (escape hatch) -
find_zips— reverse lookup: place → ZIPs, ranked by land coverage -
get_demographicsage brackets (under-18 / 18-34 / 35-64 / 65+) - Publish to PyPI (
mcpwright-census) + the official MCP Registry
Questions & feedback
- Questions, ideas, or "could it do X?" → Discussions
- Bugs & concrete feature requests → Issues
Contributions welcome.
Part of mcpwright · built by Devender Gollapally
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mcpwright_census-0.1.0.tar.gz.
File metadata
- Download URL: mcpwright_census-0.1.0.tar.gz
- Upload date:
- Size: 21.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.17 {"installer":{"name":"uv","version":"0.11.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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c01e1f5af4776264385a65f7003f9b64037e97c0972cf6bfb59549ae74d4ac49
|
|
| MD5 |
b85d3925d6c1bac914cc1236370e7d8e
|
|
| BLAKE2b-256 |
ec6b0bba8f4f120964507b4e9b676053c0ab7ca161fbeab9905f6d18ed707966
|
File details
Details for the file mcpwright_census-0.1.0-py3-none-any.whl.
File metadata
- Download URL: mcpwright_census-0.1.0-py3-none-any.whl
- Upload date:
- Size: 25.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.17 {"installer":{"name":"uv","version":"0.11.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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
269cd4a527637aab61973c7aec85ee9bb0b3a32789e4c88a85cf5663d4570468
|
|
| MD5 |
2206bffd34804fd60c2119cb928acc8f
|
|
| BLAKE2b-256 |
c6f9fd61a124c92a1b036b730b86fe55535bbee7f75484019189f3f28925a7ff
|