Server data from the Official MCP Registry
U.S. Census (ACS) data by ZIP: income, demographics, housing, education, from a local store.
U.S. Census (ACS) data by ZIP: income, demographics, housing, education, from a local store.
Valid MCP server (1 strong, 3 medium validity signals). No known CVEs in dependencies. Package registry verified. Imported from the Official MCP Registry.
7 files analyzed · 1 issue found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Set these up before or after installing:
Environment variable: CENSUS_API_KEY
Add this to your MCP configuration file:
{
"mcpServers": {
"io-github-mcpwright-census-mcp": {
"env": {
"CENSUS_API_KEY": "your-census-api-key-here"
},
"args": [
"mcpwright-census"
],
"command": "uvx"
}
}
}From the project's GitHub README.
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: published (v0.1.0) —
uvx mcpwright-census(PyPI) and listed in the official MCP Registry asio.github.mcpwright/census-mcp. All 8 tools below are live and unit-tested, verified end-to-end against the live ACS 5-year release (vintage 2024 at the time of writing — the server auto-detects the latest). Part of the mcpwright suite.
| 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).
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 mcp add census -e CENSUS_API_KEY=your-free-key -- uvx mcpwright-census
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.
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
lookup_zip — validate a ZIP, name + populationget_income — income measures + % $200k+get_demographics — population + median age (age brackets still to come)get_housing — median home value, rent, % owner-occupiedget_education — % bachelor's+, % graduatecompare_zips — one metric across several ZIPs, rankedget_acs_variable — raw value for any stored ACS variable (escape hatch)find_zips — reverse lookup: place → ZIPs, ranked by land coverageget_demographics age brackets (under-18 / 18-34 / 35-64 / 65+)mcpwright-census) + the official MCP RegistryContributions welcome.
Part of mcpwright · built by Devender Gollapally
Be the first to review this server!
by Modelcontextprotocol · Developer Tools
Read, search, and manipulate Git repositories programmatically
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace · Developer Tools
Create, build, and publish Python MCP servers to PyPI — conversationally.