Skip to main content

Build, validate, and index web-optimized GeoJSON precinct, school district, etc. files for state repos

Project description

civic-geo-generator

PyPI Python versions License: MIT CI Status Docs

Lightweight CLI and library to build web-optimized GeoJSON for election precincts (and similar layers).
Outputs three artifacts per run:

  • full GeoJSON (QA and reproducibility)
  • web GeoJSON (served to apps)
  • TopoJSON (optional, for smaller delivery)

It also writes per-version metadata.json, and a state index.json that points to the latest layer.

Installation

pip install civic-geo-generator

Quick start

# install deps
uv sync --extra dev --extra docs --upgrade

# orchestrated runs based on yaml file
uv run civic-gen run -f inputs.yaml

# or provide a specific state and view
uv run civic-gen run MN precincts

Conventions

  • Batch inputs live in inputs.yaml.
  • Config files live under data-config/ (e.g., us/mn/precincts.yaml).
  • Data input files should be placed in the data-in folder, organized by state and layer as described in YAML configs (e.g., data-config/us/mn/precincts.yaml).
  • Outputs are written under data-out/us/<state-name>/<view>/<version>/.

Links


Pipeline

Place statewide GeoJSON input in correct location, e.g.

  • data-in/us/mn/precincts_2025-04.json

Configure inputs.yaml, e.g.

# inputs.yaml  (batch mode)
runs:
  - state: MN
    views: [precincts]
    version_overrides:
      precincts: "2025-04"
# 1) Build (copy/normalize/add snapshot metadata)
civic-gen build --version 2025-04

# 2) Validate (CRS, required columns, geometry, basic uniqueness)
civic-gen validate --version 2025-04

# 3) Index (flat index, manifest, state layer pointers)
civic-gen index

Development

See DEVELOPER.md

Available: Minnesota Precincts

They include voting precinct boundaries as well as the name, county, and election districts (US Congress, MN Senate and House, County Commissioner) for each precinct.

Geojson files are intended to provide basic information regarding the location of election districts within the state. For the most accurate information on precincts and districts, as well as polling place information, please use the Polling Place Finder.

Minnesota precincts - April 2025 (6225 KB json)

Congressional District as of April 2025
District 1 (southern Minnesota) C.D. 1 (1062 KB json)
District 2 (south Metro) C.D. 2 (383 KB json)
District 3 (greater Hennepin County) C.D. 3 (341 KB json)
District 4 (Ramsey County and suburbs) C.D. 4 (217 KB json)
District 5 (Minneapolis and suburbs) C.D. 5 (171 KB json)
District 6 (northwestern Metro, St Cloud area) C.D. 6 (578 KB json)
District 7 (western Minnesota) C.D. 7 (1760 KB json)
District 8 (northeastern Minnesota) C.D. 8 (1720 KB json)

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

civic_geo_generator-0.1.3.tar.gz (169.8 kB view details)

Uploaded Source

Built Distribution

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

civic_geo_generator-0.1.3-py3-none-any.whl (26.9 kB view details)

Uploaded Python 3

File details

Details for the file civic_geo_generator-0.1.3.tar.gz.

File metadata

  • Download URL: civic_geo_generator-0.1.3.tar.gz
  • Upload date:
  • Size: 169.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for civic_geo_generator-0.1.3.tar.gz
Algorithm Hash digest
SHA256 3b18c5b98a42a26cab21d2195e4019e0990f020338d6677fe99faa75c97725d4
MD5 899117f335f398b991642af885b56ff1
BLAKE2b-256 d419a28ce2f6ec410bef24c585eb6c41b55b184469bea0a38fbc059c2ce0fbdf

See more details on using hashes here.

Provenance

The following attestation bundles were made for civic_geo_generator-0.1.3.tar.gz:

Publisher: release.yml on civic-interconnect/civic-geo-generator

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file civic_geo_generator-0.1.3-py3-none-any.whl.

File metadata

File hashes

Hashes for civic_geo_generator-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 35f0f2106df89bb8c1ea6b3183f5d92b334e5f14e6b05f61bcd31b73c2e64b05
MD5 5d2f989de4f3c18cd9396e79443c0c79
BLAKE2b-256 1478e3f6160cea91378f3d565b38a52c9a0a7fbd6ee8c2319b96d5f37763421e

See more details on using hashes here.

Provenance

The following attestation bundles were made for civic_geo_generator-0.1.3-py3-none-any.whl:

Publisher: release.yml on civic-interconnect/civic-geo-generator

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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