Skip to main content

A pure-Python library for the Hebrew calendar: conversion, astronomy, holidays and religious times, computed entirely locally.

Project description

hebrewcal

CI Documentation Status PyPI version Python versions License: MIT DOI

A pure-Python library for the Hebrew calendar.

hebrewcal makes the Hebrew calendar usable programmatically and converts it bidirectionally against the Gregorian and Julian calendars. Every computation is performed locally — the library never issues network calls to any external service.

It is built for two audiences:

  • Religious use — holidays (Israel and the Diaspora, including minority feasts and Shushan Purim), Shabbat candle lighting and Havdalah, zmanim, Torah readings, the Omer count, yahrzeit, and the sabbatical and jubilee cycle.
  • Academic use — historical, medieval and ancient dates, Babylonian and biblical month names, proleptic calendars, the Julian/Gregorian reform, and the documented "missing years" of the Anno Mundi count.

Project status. Feature-complete against the roadmap: calendar core and conversion, astronomy, holidays, religious times, and alternative calendars are all implemented, documented and tested.

Installation

pip install hebrewcal

hebrewcal requires Python 3.11+ and has no runtime dependencies (standard library only).

Quick start

from hebrewcal import GregorianDate, HebrewDate, to_hebrew, to_gregorian, weekday

# What Hebrew date and weekday corresponds to 31 October 1867?
g = GregorianDate(1867, 10, 31)
h = to_hebrew(g)
print(h)            # HebrewDate(year=5628, month=8, day=2)  -> 2 Marheshvan 5628
print(weekday(g).name)   # THURSDAY

# Convert a Hebrew date back to Gregorian.
print(to_gregorian(HebrewDate(5785, 7, 1)))   # GregorianDate(year=2024, month=10, day=3)

Every calendar reduces a date to an integer Rata Die (RD) day count and rebuilds a date from it, so any two calendars are interconvertible through RD:

from hebrewcal import GregorianDate, to_julian

GregorianDate(2026, 6, 26).to_rd()     # 739793
to_julian(GregorianDate(2026, 6, 26))  # JulianDate(year=2026, month=6, day=13)

Features

  • Proleptic Gregorian and Julian calendars (explicit, configurable Julian/Gregorian reform) and a complete Hebrew calendar (molad/halakim, dechiyot, year typing, keviah, Metonic cycle), all interconvertible through Rata Die.
  • Parsing (ISO 8601, DIN 5008, slash form), formatting, a gematria converter, month/weekday name tables (transliteration, Babylonian, biblical), and the Anno Mundi era with the documented "missing years" notice.
  • Astronomy (pure Python): solar position, sunrise/sunset, twilight, the molad as a civil instant.
  • Holidays for Israel and the Diaspora: festivals, fasts (with postponement), modern Israeli days, minority feasts, Rosh Chodesh, the Omer and the special Shabbatot.
  • Religious times: Shabbat candle lighting and Havdalah, zmanim, the molad announcement, yahrzeit, Torah readings, and the Shmita cycle.
  • Alternative calendars: the Qumran 364-day calendar, plus documented computed Samaritan and Karaite models.
  • An optional command-line interface (see below).

Command line

Installing the package provides a hebrewcal command (and python -m hebrewcal):

$ hebrewcal convert 1867-10-31
2 Marheshvan 5628 (Yom Chamishi)

$ hebrewcal shabbat 2026-06-26 --lat 40.71 --lon -74.01 --tz America/New_York
Candle lighting: 20:13
Havdalah: 21:21

Documentation

Full documentation, including a user guide with many examples, lives at hebrewcal.readthedocs.io.

Development

git clone https://github.com/bsesic/hebrewcal.git
cd hebrewcal
python -m venv .venv && source .venv/bin/activate
pip install -e ".[dev]"
pre-commit install

Run the lint gate and the test suite:

flake8
ruff check .
mypy
pytest

See CONTRIBUTING.md for the branching strategy and conventions.

Citation

If you use hebrewcal in academic work, please cite it. Citation metadata is provided in CITATION.cff, and each release is archived on Zenodo.

  • Concept DOI (always resolves to the latest version): 10.5281/zenodo.20583972
  • Each release also has its own version-specific DOI on the Zenodo record.

License

MIT © Benjamin Schnabel

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

hebrewcal-1.1.0.tar.gz (38.7 kB view details)

Uploaded Source

Built Distribution

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

hebrewcal-1.1.0-py3-none-any.whl (47.1 kB view details)

Uploaded Python 3

File details

Details for the file hebrewcal-1.1.0.tar.gz.

File metadata

  • Download URL: hebrewcal-1.1.0.tar.gz
  • Upload date:
  • Size: 38.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for hebrewcal-1.1.0.tar.gz
Algorithm Hash digest
SHA256 b1d0f569f1e0434f49122a5afc4b6c9c09dea7278dc15f58552d99f9b0d7f158
MD5 b90972d96da28c660825cea06dd5f017
BLAKE2b-256 a3f41a94ff0e37d2c01158ce40e02aa1a5b92c4ea135189391059473bbd30acb

See more details on using hashes here.

Provenance

The following attestation bundles were made for hebrewcal-1.1.0.tar.gz:

Publisher: release.yml on bsesic/hebrewcal

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

File details

Details for the file hebrewcal-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: hebrewcal-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 47.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for hebrewcal-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 76978c1d5bb8999e06b4d1cc2be43e773016503fcccb74f2e66b71e3ab40145a
MD5 a88f142a490bf5c0f43af3d78413e264
BLAKE2b-256 df1273f235025632ea7cc67b7a0b9a894a9c638b9d88a36e91ff6a26137eb40a

See more details on using hashes here.

Provenance

The following attestation bundles were made for hebrewcal-1.1.0-py3-none-any.whl:

Publisher: release.yml on bsesic/hebrewcal

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