Skip to main content

Calendario de festivos oficiales y eventos culturales de Colombia (Ley Emiliani)

Project description

calendary_co

Calendario de festivos oficiales y eventos culturales de Colombia, con soporte para la Ley Emiliani (vía colombian-holidays) y ventana rodante de 3 años (año actual + 2 siguientes).

Instalación

pip install calendary_co

Desarrollo local:

pip install -e "ruta/a/LIBRERIAS py/calendary_co"

Con dependencias de desarrollo (pytest):

pip install -e "ruta/a/LIBRERIAS py/calendary_co[dev]"

Ventana rodante de años

El paquete precalienta automáticamente el año en curso y los dos siguientes. No hace falta añadir años manualmente cada enero:

from datetime import date
from calendary_co import get_active_years, get_full_calendar

# Con fecha de referencia (útil en tests)
ref = date(2026, 7, 2)
print(list(get_active_years(ref)))  # [2026, 2027, 2028]

calendario = get_full_calendar(ref)  # {2026: [...], 2027: [...], 2028: [...]}

Consultas fuera de la ventana activa siguen funcionando (cálculo bajo demanda).

Demo rápido

Script de prueba incluido en el repositorio:

cd "LIBRERIAS py/calendary_co"
pip install -e .
python demo_calendary.py

Muestra festivos y eventos culturales entre dos fechas (edita FECHA_INICIO y FECHA_FIN en el archivo).

API principal

Festivos oficiales

from datetime import date
from calendary_co import is_holiday, get_holiday_name, get_holidays_for_year

d = date(2026, 7, 20)
is_holiday(d)           # True (festivo o domingo)
get_holiday_name(d)     # "Día de la Independencia (Independence Day)"
get_holidays_for_year(2026)  # lista de (fecha, nombre), 18 festivos legales

Consulta por rango (recomendado)

Solo festivos nombrados y eventos culturales entre dos fechas, con día de la semana en español:

from datetime import date
from calendary_co import consultar_festividades, format_consulta_festividades

inicio = date(2026, 6, 1)
fin = date(2026, 6, 30)

resultados = consultar_festividades(inicio, fin)

# Filtrar por nivel (opcional):
# consultar_festividades(inicio, fin, niveles=["nacional"])
# consultar_festividades(inicio, fin, niveles=["municipal", "regional"])
# consultar_festividades(inicio, fin, niveles=["municipal"])

# resultados["festivos_oficiales"]  -> festivos legales (siempre, independiente del filtro niveles)
# resultados["eventos_culturales_rangos"]  -> culturales agrupados por fechas
# resultados["niveles_aplicados"]  -> niveles usados en la consulta
# resultados["dias"]  -> detalle por dia (uso avanzado)

print(format_consulta_festividades(resultados, inicio, fin))

No incluye días vacíos (sin festivo nombrado ni evento cultural). Los domingos sin actividad cultural no aparecen.

Contexto detallado para un día o rango

from datetime import date
from calendary_co import get_calendar_context, get_calendar_contexts, format_context_for_prompt

ctx = get_calendar_context(date(2026, 12, 27), segment_id="21701_CALI_SEGMENTO")
# ctx.is_holiday_or_sunday, ctx.holiday_name, ctx.cultural_events, ctx.season

contextos = get_calendar_contexts(date(2026, 7, 14), date(2026, 7, 20), segment_id="21701_CALI_SEGMENTO")
texto_xml = format_context_for_prompt(contextos)

Validación de temporalidad

Evita mensajes incoherentes (por ejemplo, “Feliz Navidad” en julio):

from datetime import date
from calendary_co import validar_temporalidad_mensaje

validar_temporalidad_mensaje("Feliz Navidad", date(2026, 7, 20))  # False
validar_temporalidad_mensaje("Recuerda tu pago", date(2026, 7, 20))  # True

Eventos incluidos

Festivos oficiales: 18 festivos legales + domingos (Ley Emiliani, Pascua, traslados).

Culturales nacionales: Velitas, Novena de Aguinaldos, Amor y Amistad, Día de la Madre/Padre, Halloween, Semana Santa, etc.

Municipales: ferias y fiestas patronales por municipio (referencia MINCIT), incluyendo San Juan (24 de junio) y Fiestas de San Juan y San Pedro en Tolima y Huila. San Pedro y San Pablo es festivo oficial (Ley Emiliani).

Ferias regionales: Carnaval de Barranquilla, Feria de Cali, Feria de las Flores, Leyenda Vallenata, Carnaval de Negros y Blancos, Feria de Manizales, y más en municipal_events.py.

colombia.co: eventos adicionales desde colombia.co/eventos (API /mark-events/events/{año}/{mes}/es), empaquetados en calendary_co/data/colombia_co_events.json. Actualizar con python scripts/sync_colombia_co_events.py.

Los eventos municipales y regionales se filtran por segment_id con tokens como _CALI_, _IBAGUÉ_, _NEIVA_, _EL_ESPINAL_, etc.

Integración (agente 4)

Instalar calendary_co como dependencia del proyecto agente. En el prompt dinámico:

from datetime import date
from calendary_co import get_calendar_contexts, format_context_for_prompt

fechas = [date.fromisoformat(d) for d in dias_bloque]
contexto_text = format_context_for_prompt(
    get_calendar_contexts(fechas[0], fechas[-1], segmento_id)
)
# Inyectar en <contexto_temporal>{contexto_text}</contexto_temporal>

En validación post-LLM:

from datetime import date
from calendary_co import validar_temporalidad_mensaje

for item in plan:
    fecha = date.fromisoformat(item["fecha"])
    if not validar_temporalidad_mensaje(item["mensaje"], fecha, segmento_id):
        raise ValueError("Mensaje temporalmente incoherente")

Tests

cd "LIBRERIAS py/calendary_co"
python -m pytest tests/ -v

Publicación en PyPI

pip install --upgrade build twine
python -m build
python -m twine upload dist/*

Paquete: pip install calendary_co

Licencia

MIT — Copyright (c) 2026 Alejandro Galicia. Derechos de autor reservados al titular; la licencia permite uso, modificación y distribución libre en proyectos personales, comerciales y de código abierto, con inclusión del aviso de copyright. Ver LICENSE.

Dependencias

  • colombian-holidays>=1.0.0 — festivos oficiales Colombia (Ley Emiliani)
  • python-dateutil>=2.8.2 — cálculo de Pascua y eventos móviles

Relación con contact_co

contact_co usa holidays.Colombia() para validación legal de contacto. calendary_co es independiente y está orientado al contexto temporal de mensajes (prompts y validación). Una migración futura de contact_co a calendary_co es opcional.

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

calendary_co-0.1.0.tar.gz (24.7 kB view details)

Uploaded Source

Built Distribution

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

calendary_co-0.1.0-py3-none-any.whl (21.4 kB view details)

Uploaded Python 3

File details

Details for the file calendary_co-0.1.0.tar.gz.

File metadata

  • Download URL: calendary_co-0.1.0.tar.gz
  • Upload date:
  • Size: 24.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for calendary_co-0.1.0.tar.gz
Algorithm Hash digest
SHA256 34201483b9b3d3989da0382b7a1387447de235e5d9625e9ff800666a6257ab0c
MD5 5084213e5aa53740f74cc014142f0e52
BLAKE2b-256 c34214d63f2f608d56320be204cea84ecb51885c927dc06864e51b3927709700

See more details on using hashes here.

File details

Details for the file calendary_co-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: calendary_co-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 21.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for calendary_co-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 234d1de48c59dbcdd5f3ac4c037054d8af17e374b0ae53ec365be1f4ce9317f8
MD5 5596469adc77e1c676ae81f8ab0c0375
BLAKE2b-256 c5e2cc114cb3d26ad94a53f6c8d5ec31c3680c8fa4d726431699e14ac29efe9e

See more details on using hashes here.

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