Skip to main content

Philippines Standard Geographic Code (PSGC) 2026 Python package, Fuzzy Search, JSON, and YAML.

Project description

🇵🇭 barangay

PyPI version PyPI Downloads License: MIT Release Visit the Docs zread

Philippine Standard Geographic Code (PSGC) Python package with fuzzy search for barangays, municipalities, cities, provinces, and regions. Based on the official April 2026 PSGC masterlist. Offline access to all 42,011 barangays — no API calls or database needed.


Quick Start

pip install barangay
from barangay import barangays, search_fuzzy

# Browse all 42,011 barangays
print(barangays)  # <PSGC barangay database: 42010 records>

# Get a specific barangay
brgy = barangays.get(name="Tongmageng")
print(brgy.region)    # Bangsamoro Autonomous Region In Muslim Mindanao (BARMM)
print(brgy.province)  # Tawi-Tawi
print(brgy.psgc_id)   # 1907005010

# Fuzzy search
for r in search_fuzzy("Tongmagen, Tawi-Tawi"):
    print(f"{r.name} — score: {r.score}")

Features

Feature Description
🔍 Fuzzy Search Fast, customizable matching for unstandardized addresses
🏛️ Hierarchy Traversal Navigate parent, children, and ancestors of any admin division
📊 Pandas Export Direct to_frame() / to_dicts() export from database views
Address Validation validate() and validate_many() for automated address checking
📅 Historical Data Access previous PSGC releases by date
👩‍💻 Command Line Interface Easy-to-use command line interface
📚 Multiple Data Models Choose the structure that fits your use case
💾 Smart Caching Automatic caching for faster subsequent loads
🧩 Plug-in System Enrich PSGC data with custom extensions via plug-ins

Installation

pip install barangay

Requirements: Python 3.13+


CLI

# Search for barangays
barangay search "Tongmageng, Tawi-Tawi"

# Export data
barangay export --model flat --format json --output data.json

# Show information
barangay info version
barangay info stats

# Work with historical data
barangay history list-dates
barangay history search-history "Tongmageng" --as-of "2025-07-08"

# Manage cache
barangay cache info
barangay cache clear

# Search with plugin enrichment
barangay search "Tongmageng" --plugin psgc-aux-data --format json

# Export with plugin enrichment
barangay export --model flat --plugin psgc-aux-data --format json --output enriched.json

# Batch operations
barangay batch batch-search queries.txt --limit 5 --output results.json
barangay batch validate barangay_names.txt

📖 Full CLI Reference: docs/cli.md 📖 Plugin Guide: docs/plugins/index.md


Python API

Database Views

Pre-built views let you browse and search any admin level directly:

from barangay import regions, provinces, municipalities, cities, barangays

print(regions)     # <PSGC region database: 18 records>
print(barangays)   # <PSGC barangay database: 42010 records>

# Look up by name
brgy = barangays.get(name="Tongmageng")
print(brgy.province)  # Tawi-Tawi

# Look up by PSGC ID
brgy = barangays.lookup("1907005010")
print(brgy)  # <barangay: Tongmageng (1907005010)>

# Iterate over records
for region in regions:
    print(region.name)

Hierarchy Traversal

Each record exposes its position in the administrative hierarchy:

brgy = barangays.get(name="Tongmageng")
print(brgy.region)      # Bangsamoro Autonomous Region In Muslim Mindanao (BARMM)
print(brgy.province)    # Tawi-Tawi
print(brgy.municipality)  # Sitangkai
print(brgy.parent)      # <municipality: Sitangkai (1907005000)>
print(brgy.ancestors)   # [<municipality: Sitangkai ...>, <province: Tawi-Tawi ...>, ...]

manila = cities.get(name="City of Manila")
print(manila.children[:2])  # [<submunicipality: Tondo I/II ...>, <submunicipality: Binondo ...>]

Fuzzy Search

from barangay import search_fuzzy

results = search_fuzzy("Tongmagen, Tawi-Tawi", threshold=60.0, limit=5)
for r in results:
    print(f"{r.name} ({r.psgc_id}) — score: {r.score}")
# Tongmageng (1907005010) — score: 100.0
# Tonggosong (1907004005) — score: 84.21
# ...

Address Validation

from barangay import validate, validate_many

v = validate("Tongmageng, Tawi-Tawi")
print(v.valid, v.matched_name, v.score)  # True Tongmageng 100.0

results = validate_many(["Tongmageng, Tawi-Tawi", "Nonexistent Place"])
for r in results:
    print(f"{r.input!r} -> {'valid' if r.valid else 'invalid'}")

Export to Pandas

from barangay import barangays

df = barangays.to_frame()     # pd.DataFrame
data = barangays.to_dicts()   # List[dict]

Data Access (Nested & Flat Models)

from barangay import barangay, barangay_flat, barangay_extended

# Basic nested model (simple lookups)
ncr_cities = list(barangay["National Capital Region (NCR)"].keys())

# Extended model (recursive with metadata)
for region in barangay_extended.components:
    print(f"{region.name} ({region.type})")

# Flat model (search & filtering)
brgy = [loc for loc in barangay_flat if loc.name == "Marayos"][0]

Search (Dict-based)

Deprecated: The search() function returns raw dicts and will be removed in 2027.X.X.X. Use search_fuzzy() instead for typed results.

from barangay import search

# Simple search
results = search("Tongmageng, Tawi-Tawi")

# Custom search
search(
    "Tongmagen, Tawi-Tawi",
    n=4,                    # Number of results
    match_hooks=["municipality", "barangay"],  # Match levels
    threshold=70.0,         # Minimum similarity (0-100)
)

Utilities

from barangay import sanitize_input, resolve_date, get_available_dates, use_version

# Sanitize strings
cleaned = sanitize_input("City of San Jose", exclude=["city of "])
# Result: "san jose"

# Switch to historical data
use_version("2025-07-08")
brgy = barangays.lookup("1907005010")
use_version(None)  # back to latest

📖 Full API Reference: docs/api.md


Configuration

Configure via environment variables:

export BARANGAY_AS_OF="2025-07-08"      # Default dataset date
export BARANGAY_VERBOSE="true"          # Enable verbose logging
export BARANGAY_CACHE_DIR="/custom/path" # Custom cache directory

Or set programmatically:

import barangay
barangay.as_of = "2025-07-08"

Priority: Function parameter → Module attribute → Environment variable → Default (latest)

📖 Full Configuration Guide: docs/configuration.md


Data Models

Three data structures are available. Choose based on your use case:

Model Use Case Structure
barangay Simple lookups Nested dictionary (region → city → barangay)
barangay_extended Complex hierarchies Recursive with rich metadata
barangay_flat Search & filtering Flat list with parent references

Note: Pydantic models (barangay, barangay_extended, barangay_flat) are recommended. Dict versions (BARANGAY, BARANGAY_EXTENDED, BARANGAY_FLAT) are available for backward compatibility.

Deprecation: BARANGAY, BARANGAY_EXTENDED, BARANGAY_FLAT dict aliases will be removed in 2027.X.X.X. Use the Database API instead (e.g. from barangay import barangays; barangays.get(name="Tongmageng")).


Historical Data

Access previous PSGC releases by date. Data is automatically cached after first download.

Current Data Version: 2026-04-13 (April 13 2026 PSGC masterlist)

Available Dates:

  • Current: 2026-04-13 (bundled)
  • Historical: 2026-01-13, 2025-07-08, 2025-08-29, 2025-10-13
import barangay
print(barangay.current)           # '2026-04-13'
print(barangay.available_dates)   # ['2026-04-13', '2026-01-13', '2025-08-29', '2025-10-13', '2025-07-08']

Performance

Fuzzy search is optimized for speed:

Configuration Performance
Default (3 hooks) ~80ms per search
Optimized (2 hooks) ~25ms per search

Use fewer match_hooks for better performance when appropriate.


Resources


Contributing

Contributions are welcome! See our Contributing Guide and Code of Conduct.


License

MIT © bendlikeabamboo

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

barangay-2026.4.13.2.tar.gz (3.0 MB view details)

Uploaded Source

Built Distribution

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

barangay-2026.4.13.2-py3-none-any.whl (2.9 MB view details)

Uploaded Python 3

File details

Details for the file barangay-2026.4.13.2.tar.gz.

File metadata

  • Download URL: barangay-2026.4.13.2.tar.gz
  • Upload date:
  • Size: 3.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for barangay-2026.4.13.2.tar.gz
Algorithm Hash digest
SHA256 1eba3a4811f3ae1b1839bc9f1d0bcc67eaffacdbce89cb19a8486a0b0d5eebac
MD5 14f4cf1b70ce81d9ca3eb7576987d56a
BLAKE2b-256 7a0311988ca427020c47689ee93ac847446abfc3879450ccb357d43a342c9aec

See more details on using hashes here.

Provenance

The following attestation bundles were made for barangay-2026.4.13.2.tar.gz:

Publisher: publish.yaml on bendlikeabamboo/barangay

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

File details

Details for the file barangay-2026.4.13.2-py3-none-any.whl.

File metadata

  • Download URL: barangay-2026.4.13.2-py3-none-any.whl
  • Upload date:
  • Size: 2.9 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for barangay-2026.4.13.2-py3-none-any.whl
Algorithm Hash digest
SHA256 b2a8330fa8cebcbd2fc2d0324e5fcf8e6221a7411295dcc9f91aca9a7bd6d70c
MD5 61012835fbb5e47b57cb170205ba6bc5
BLAKE2b-256 1e49693a7cc6393854bd73199ba534955290d11b6125a67123cacbb5dbcc0a32

See more details on using hashes here.

Provenance

The following attestation bundles were made for barangay-2026.4.13.2-py3-none-any.whl:

Publisher: publish.yaml on bendlikeabamboo/barangay

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