Skip to main content

Manages trade dates.

Project description

tradingdate

Manages trade dates.

Installation

$ pip install tradingdate

Requirements

chinesecalendar

Usage

Get a calendar

>>> import tradingdate as td
>>> cal = td.get_calendar("chinese") # by default "chinese"
>>> cal
TradingCalendar(20040102 ~ 20251231, 'chinese')
>>> list(cal)[:3]
[TradingDate(20040102), TradingDate(20040105), TradingDate(20040106)]

Get a trading date

>>> date = td.get_trading_date(20250116)
>>> date
TradingDate(20250116)
>>> print(date.year, date.month, date.day)
2025 01 16
>>> date - 20
TradingDate(20241218)
>>> date + 100
TradingDate(20250617)
>>> date.month.start, date.month.end
(TradingDate(20250102), TradingDate(20250127))
>>> date.year.start, date.year.end
(TradingDate(20250102), TradingDate(20251231))

Get trading dates

>>> list(td.get_trading_dates(20250101, 20250106))
[TradingDate(20250102), TradingDate(20250103), TradingDate(20250106)]

Make a new calendar

>>> td.make_calendar("user-defined", [20250101, 20250115, 20250201])
TradingCalendar(20250101 ~ 20250201, 'user-defined')
>>> list(td.get_trading_dates(20250101, 20250131, calendar_id="user-defined"))
[TradingDate(20250101), TradingDate(20250115)]

See Also

Github repository

PyPI project

License

This project falls under the BSD 3-Clause License.

History

v0.0.6

  • New function daterange().

v0.0.5

  • New property TradingDate.week.

v0.0.4

  • Improved effeciency when making a calendar.
  • Updated message of NotImplementedError raised by CalendarEngine.get_chinese_calendar().

v0.0.3

  • Updated make_calendar(): now accepts a date-list as the second positional argument instead of a dict.

v0.0.2

  • New function make_calendar().
  • Removed the dependency on numpy.

v0.0.1

  • New methods TradingCalendar.get_year(), YearCalendar.get_month(), MonthCalendar.get_day().
  • Bugfix: TradingDate.__sub__().

v0.0.0

  • Initial release.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

tradingdate-0.0.6-py2.py3-none-any.whl (9.0 kB view details)

Uploaded Python 2Python 3

File details

Details for the file tradingdate-0.0.6-py2.py3-none-any.whl.

File metadata

  • Download URL: tradingdate-0.0.6-py2.py3-none-any.whl
  • Upload date:
  • Size: 9.0 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.8.13

File hashes

Hashes for tradingdate-0.0.6-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 79a330bdc51d3d1b4417191fe8620cfc9bd988f740f08ce6ddcee821671feeb7
MD5 6e3f31e3a76b64460552bb13b89047df
BLAKE2b-256 dd150a15b498ea8810acbb2a257fdacce003c1317de246d33b71196f19086383

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