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

Philippine geographic data with fuzzy search. Based on the January 2026 PSGC masterlist.


Quick Start

pip install barangay
from barangay import search

# Find barangays with fuzzy matching
results = search("Tongmageng, Tawi-Tawi")
print(results[0]['barangay'])  # Tongmageng

Features

Feature Description
🔍 Fuzzy Search Fast, customizable matching for unstandardized addresses
📅 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
📦 Ready-to-Use JSON, YAML, and Python dictionary formats included

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

# 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


Python API

Fuzzy Search

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)
)

# Historical data
search("Tongmageng", as_of="2025-07-08")

Data Access

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]

Utilities

from barangay import sanitize_input, resolve_date, get_available_dates

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

# Resolve to closest available date
resolved_date, status = resolve_date("2025-07-01", get_available_dates(), "2026-01-13")
# Result: '2025-07-08'

# Get all available dates
dates = get_available_dates()
# ['2026-01-13', '2025-08-29', '2025-10-13', '2025-07-08']

📖 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.


Historical Data

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

Current Data Version: 2026-01-13 (January 13 2026 PSGC masterlist)

Available Dates:

  • Current: 2026-01-13 (bundled)
  • Historical: 2025-07-08, 2025-08-29, 2025-10-13
import barangay
print(barangay.current)           # '2026-01-13'
print(barangay.available_dates)   # ['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.1.13.3.tar.gz (2.9 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.1.13.3-py3-none-any.whl (2.9 MB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for barangay-2026.1.13.3.tar.gz
Algorithm Hash digest
SHA256 078769696a7b3d343379843bc31feaa6e21d407e4f04df169892c48010244e1b
MD5 a1b27e93a3bc8749a6a10fa01dca8bcc
BLAKE2b-256 bf7ac6707b23d0a8194c69a7a53716c469e1f8d60a82588d5ac61b51ff3283fd

See more details on using hashes here.

Provenance

The following attestation bundles were made for barangay-2026.1.13.3.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.1.13.3-py3-none-any.whl.

File metadata

  • Download URL: barangay-2026.1.13.3-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.7

File hashes

Hashes for barangay-2026.1.13.3-py3-none-any.whl
Algorithm Hash digest
SHA256 07b2a25ca23ceaad63d47e249ae358175e017e987e4c0d3a8b38ead00bff1db0
MD5 915a955512fd8157bbe26efde85bc58b
BLAKE2b-256 278bcf6e571e90c0f8b52c8c51da03ccc804c96248a5c282b0d54776f522bf0f

See more details on using hashes here.

Provenance

The following attestation bundles were made for barangay-2026.1.13.3-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