Spans 1.0.0 documentation¶
Spans is a pure Python implementation of PostgreSQL’s range types. Range types are conveinent when working with intervals of any kind. Every time you’ve found yourself working with date_start and date_end, an interval may have been what you were actually looking for.
Spans has successfully been used in production since its first release 30th August, 2013.
Imagine you are building a calendar and want to display all weeks that overlaps the current month. Normally you have to do some date trickery to achieve this, since the month’s bounds may be any day of the week. With Spans’ set-like operations and shortcuts the problem becomes a breeze.
We start by importing
>>> from datetime import date >>> from spans import daterange
daterange.from_month we can get range representing January in the year
>>> month = daterange.from_month(2000, 1) >>> month daterange([datetime.date(2000, 1, 1),datetime.date(2000, 2, 1)))
Now we can calculate the ranges for the weeks where the first and last day of month are
>>> start_week = daterange.from_date(month.lower, period="week") >>> end_week = daterange.from_date(month.last, period="week") >>> start_week daterange([datetime.date(1999, 12, 27),datetime.date(2000, 1, 3))) >>> end_week daterange([datetime.date(2000, 1, 31),datetime.date(2000, 2, 7)))
Using a union we can express the calendar view.
>>> start_week.union(month).union(end_week) daterange([datetime.date(1999, 12, 27),datetime.date(2000, 2, 7)))
- Spans 1.0.0 documentation
- Custom range types
- PostgreSQL analogies
- API documentation