pandas-market-calendars 4.4.0__py3-none-any.whl → 4.6.0__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- pandas_market_calendars/__init__.py +2 -1
- pandas_market_calendars/calendar_registry.py +5 -1
- pandas_market_calendars/calendar_utils.py +1102 -163
- pandas_market_calendars/calendars/cme.py +3 -0
- pandas_market_calendars/calendars/cme_globex_agriculture.py +46 -0
- pandas_market_calendars/calendars/eurex.py +0 -8
- pandas_market_calendars/calendars/hkex.py +3 -0
- pandas_market_calendars/calendars/iex.py +43 -4
- pandas_market_calendars/calendars/jpx.py +6 -2
- pandas_market_calendars/calendars/mirror.py +19 -0
- pandas_market_calendars/calendars/nyse.py +154 -12
- pandas_market_calendars/calendars/sse.py +1 -1
- pandas_market_calendars/calendars/tase.py +24 -1
- pandas_market_calendars/holidays/cn.py +21 -0
- pandas_market_calendars/holidays/jpx_equinox.py +1 -0
- pandas_market_calendars/holidays/nyse.py +5 -0
- pandas_market_calendars/market_calendar.py +185 -23
- {pandas_market_calendars-4.4.0.dist-info → pandas_market_calendars-4.6.0.dist-info}/METADATA +13 -9
- {pandas_market_calendars-4.4.0.dist-info → pandas_market_calendars-4.6.0.dist-info}/RECORD +23 -23
- {pandas_market_calendars-4.4.0.dist-info → pandas_market_calendars-4.6.0.dist-info}/WHEEL +1 -1
- {pandas_market_calendars-4.4.0.dist-info → pandas_market_calendars-4.6.0.dist-info}/LICENSE +0 -0
- {pandas_market_calendars-4.4.0.dist-info → pandas_market_calendars-4.6.0.dist-info}/NOTICE +0 -0
- {pandas_market_calendars-4.4.0.dist-info → pandas_market_calendars-4.6.0.dist-info}/top_level.txt +0 -0
| @@ -16,14 +16,27 @@ | |
| 16 16 | 
             
            import warnings
         | 
| 17 17 | 
             
            from abc import ABCMeta, abstractmethod
         | 
| 18 18 | 
             
            from datetime import time
         | 
| 19 | 
            +
            from typing import Literal, Union
         | 
| 19 20 |  | 
| 20 21 | 
             
            import pandas as pd
         | 
| 21 22 | 
             
            from pandas.tseries.offsets import CustomBusinessDay
         | 
| 22 23 |  | 
| 23 24 | 
             
            from .class_registry import RegisteryMeta, ProtectedDict
         | 
| 24 25 |  | 
| 26 | 
            +
            from . import calendar_utils as u
         | 
| 27 | 
            +
             | 
| 25 28 | 
             
            MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY, SATURDAY, SUNDAY = range(7)
         | 
| 26 29 |  | 
| 30 | 
            +
            WEEKMASK_ABBR = {
         | 
| 31 | 
            +
                MONDAY: "Mon",
         | 
| 32 | 
            +
                TUESDAY: "Tue",
         | 
| 33 | 
            +
                WEDNESDAY: "Wed",
         | 
| 34 | 
            +
                THURSDAY: "Thu",
         | 
| 35 | 
            +
                FRIDAY: "Fri",
         | 
| 36 | 
            +
                SATURDAY: "Sat",
         | 
| 37 | 
            +
                SUNDAY: "Sun",
         | 
| 38 | 
            +
            }
         | 
| 39 | 
            +
             | 
| 27 40 |  | 
| 28 41 | 
             
            class DEFAULT:
         | 
| 29 42 | 
             
                pass
         | 
| @@ -540,7 +553,7 @@ class MarketCalendar(metaclass=MarketCalendarMeta): | |
| 540 553 |  | 
| 541 554 | 
             
                    return intr.apply(self._convert).sort_index()
         | 
| 542 555 |  | 
| 543 | 
            -
                def holidays(self):
         | 
| 556 | 
            +
                def holidays(self) -> pd.tseries.offsets.CustomBusinessDay:
         | 
| 544 557 | 
             
                    """
         | 
| 545 558 | 
             
                    Returns the complete CustomBusinessDay object of holidays that can be used in any Pandas function that take
         | 
| 546 559 | 
             
                    that input.
         | 
| @@ -557,7 +570,7 @@ class MarketCalendar(metaclass=MarketCalendarMeta): | |
| 557 570 | 
             
                        )
         | 
| 558 571 | 
             
                    return self._holidays
         | 
| 559 572 |  | 
| 560 | 
            -
                def valid_days(self, start_date, end_date, tz="UTC"):
         | 
| 573 | 
            +
                def valid_days(self, start_date, end_date, tz="UTC") -> pd.DatetimeIndex:
         | 
| 561 574 | 
             
                    """
         | 
| 562 575 | 
             
                    Get a DatetimeIndex of valid open business days.
         | 
| 563 576 |  | 
| @@ -615,21 +628,42 @@ class MarketCalendar(metaclass=MarketCalendarMeta): | |
| 615 628 |  | 
| 616 629 | 
             
                def _tryholidays(self, cal, s, e):
         | 
| 617 630 | 
             
                    try:
         | 
| 618 | 
            -
                         | 
| 631 | 
            +
                        # If the Calendar is all single Observance Holidays then it is far
         | 
| 632 | 
            +
                        # more efficient to extract and return those dates
         | 
| 633 | 
            +
                        observed_dates = u.all_single_observance_rules(cal)
         | 
| 634 | 
            +
                        if observed_dates is not None:
         | 
| 635 | 
            +
                            return pd.DatetimeIndex(
         | 
| 636 | 
            +
                                [date for date in observed_dates if s <= date <= e]
         | 
| 637 | 
            +
                            )
         | 
| 638 | 
            +
                        else:
         | 
| 639 | 
            +
                            return cal.holidays(s, e)
         | 
| 619 640 | 
             
                    except ValueError:
         | 
| 620 641 | 
             
                        return pd.DatetimeIndex([])
         | 
| 621 642 |  | 
| 622 643 | 
             
                def _special_dates(self, calendars, ad_hoc_dates, start, end):
         | 
| 623 644 | 
             
                    """
         | 
| 624 | 
            -
                    Union an iterable of pairs of the  | 
| 625 | 
            -
                     | 
| 645 | 
            +
                    Union an iterable of pairs of the forms (time, calendar),
         | 
| 646 | 
            +
                    (time, [dates]), and (time, int). If the second item in the pair
         | 
| 647 | 
            +
                    is an int it will be interpreted as a specific day of the week.
         | 
| 626 648 |  | 
| 627 649 | 
             
                    (This is shared logic for computing special opens and special closes.)
         | 
| 628 650 | 
             
                    """
         | 
| 629 | 
            -
                    indexes = [
         | 
| 630 | 
            -
             | 
| 631 | 
            -
                         | 
| 632 | 
            -
             | 
| 651 | 
            +
                    indexes = []
         | 
| 652 | 
            +
                    for time_, calendar in calendars:
         | 
| 653 | 
            +
                        if isinstance(calendar, int):
         | 
| 654 | 
            +
                            day_of_week = CustomBusinessDay(weekmask=WEEKMASK_ABBR[calendar])
         | 
| 655 | 
            +
                            indexes.append(
         | 
| 656 | 
            +
                                self.days_at_time(
         | 
| 657 | 
            +
                                    pd.date_range(start, end, freq=day_of_week), time_
         | 
| 658 | 
            +
                                )
         | 
| 659 | 
            +
                            )
         | 
| 660 | 
            +
                        else:
         | 
| 661 | 
            +
                            indexes.append(
         | 
| 662 | 
            +
                                self.days_at_time(self._tryholidays(calendar, start, end), time_)
         | 
| 663 | 
            +
                            )
         | 
| 664 | 
            +
             | 
| 665 | 
            +
                    indexes += [self.days_at_time(dates, time_) for time_, dates in ad_hoc_dates]
         | 
| 666 | 
            +
             | 
| 633 667 | 
             
                    if indexes:
         | 
| 634 668 | 
             
                        dates = pd.concat(indexes).sort_index().drop_duplicates()
         | 
| 635 669 | 
             
                        return dates.loc[start : end.replace(hour=23, minute=59, second=59)]
         | 
| @@ -669,7 +703,7 @@ class MarketCalendar(metaclass=MarketCalendarMeta): | |
| 669 703 | 
             
                    force_special_times=True,
         | 
| 670 704 | 
             
                    market_times=None,
         | 
| 671 705 | 
             
                    interruptions=False,
         | 
| 672 | 
            -
                ):
         | 
| 706 | 
            +
                ) -> pd.DataFrame:
         | 
| 673 707 | 
             
                    """
         | 
| 674 708 | 
             
                    Generates the schedule DataFrame. The resulting DataFrame will have all the valid business days as the index
         | 
| 675 709 | 
             
                    and columns for the requested market times. The columns can be determined either by setting a range (inclusive
         | 
| @@ -701,30 +735,83 @@ class MarketCalendar(metaclass=MarketCalendarMeta): | |
| 701 735 | 
             
                    if not (start_date <= end_date):
         | 
| 702 736 | 
             
                        raise ValueError("start_date must be before or equal to end_date.")
         | 
| 703 737 |  | 
| 704 | 
            -
                    # Setup all valid trading days and the requested market_times
         | 
| 705 738 | 
             
                    _all_days = self.valid_days(start_date, end_date)
         | 
| 739 | 
            +
             | 
| 740 | 
            +
                    # Setup all valid trading days and the requested market_times
         | 
| 706 741 | 
             
                    if market_times is None:
         | 
| 707 742 | 
             
                        market_times = self._get_market_times(start, end)
         | 
| 708 743 | 
             
                    elif market_times == "all":
         | 
| 709 744 | 
             
                        market_times = self._market_times
         | 
| 710 745 |  | 
| 711 | 
            -
                    # If no valid days return an empty DataFrame
         | 
| 712 | 
            -
                    if not _all_days.size:
         | 
| 746 | 
            +
                    if not _all_days.size:  # If no valid days return an empty DataFrame
         | 
| 713 747 | 
             
                        return pd.DataFrame(
         | 
| 714 748 | 
             
                            columns=market_times, index=pd.DatetimeIndex([], freq="C")
         | 
| 715 749 | 
             
                        )
         | 
| 716 750 |  | 
| 751 | 
            +
                    return self.schedule_from_days(
         | 
| 752 | 
            +
                        _all_days, tz, start, end, force_special_times, market_times, interruptions
         | 
| 753 | 
            +
                    )
         | 
| 754 | 
            +
             | 
| 755 | 
            +
                def schedule_from_days(
         | 
| 756 | 
            +
                    self,
         | 
| 757 | 
            +
                    days: pd.DatetimeIndex,
         | 
| 758 | 
            +
                    tz="UTC",
         | 
| 759 | 
            +
                    start="market_open",
         | 
| 760 | 
            +
                    end="market_close",
         | 
| 761 | 
            +
                    force_special_times=True,
         | 
| 762 | 
            +
                    market_times=None,
         | 
| 763 | 
            +
                    interruptions=False,
         | 
| 764 | 
            +
                ) -> pd.DataFrame:
         | 
| 765 | 
            +
                    """
         | 
| 766 | 
            +
                    Generates a schedule DataFrame for the days provided. The days are assumed to be valid trading days.
         | 
| 767 | 
            +
             | 
| 768 | 
            +
                    The columns can be determined either by setting a range (inclusive on both sides), using `start` and `end`,
         | 
| 769 | 
            +
                    or by passing a list to `market_times'. A range of market_times is derived from a list of market_times that
         | 
| 770 | 
            +
                    are available to the instance, which are sorted based on the current regular time.
         | 
| 771 | 
            +
                    See examples/usage.ipynb for demonstrations.
         | 
| 772 | 
            +
             | 
| 773 | 
            +
                    All time zones are set to UTC by default. Setting the tz parameter will convert the columns to the desired
         | 
| 774 | 
            +
                    timezone, such as 'America/New_York'.
         | 
| 775 | 
            +
             | 
| 776 | 
            +
                    :param days: pd.DatetimeIndex of all the desired days in ascending order. This function does not double check
         | 
| 777 | 
            +
                        that these are valid trading days, it is assumed they are. It is intended that this parameter is generated
         | 
| 778 | 
            +
                        by either the .valid_days() or .date_range_htf() methods. Time & Timezone Information is ignored.
         | 
| 779 | 
            +
                    :param tz: timezone that the columns of the returned schedule are in, default: "UTC"
         | 
| 780 | 
            +
                    :param start: the first market_time to include as a column, default: "market_open"
         | 
| 781 | 
            +
                    :param end: the last market_time to include as a column, default: "market_close"
         | 
| 782 | 
            +
                    :param force_special_times: how to handle special times.
         | 
| 783 | 
            +
                        True: overwrite regular times of the column itself, conform other columns to special times of
         | 
| 784 | 
            +
                            market_open/market_close if those are requested.
         | 
| 785 | 
            +
                        False: only overwrite regular times of the column itself, leave others alone
         | 
| 786 | 
            +
                        None: completely ignore special times
         | 
| 787 | 
            +
                    :param market_times: alternative to start/end, list of market_times that are in self.regular_market_times
         | 
| 788 | 
            +
                    :param interruptions: bool, whether to add interruptions to the schedule, default: False
         | 
| 789 | 
            +
                        These will be added as columns to the right of the DataFrame. Any interruption on a day between
         | 
| 790 | 
            +
                        start_date and end_date will be included, regardless of the market_times requested.
         | 
| 791 | 
            +
                        Also, `force_special_times` does not take these into consideration.
         | 
| 792 | 
            +
                    :return: schedule DataFrame
         | 
| 793 | 
            +
                    """
         | 
| 794 | 
            +
             | 
| 795 | 
            +
                    if days.dtype != "datetime64[ns]":
         | 
| 796 | 
            +
                        days = pd.DatetimeIndex(days).normalize().tz_localize(None)
         | 
| 797 | 
            +
             | 
| 798 | 
            +
                    # Setup all valid trading days and the requested market_times
         | 
| 799 | 
            +
                    if market_times is None:
         | 
| 800 | 
            +
                        market_times = self._get_market_times(start, end)
         | 
| 801 | 
            +
                    elif market_times == "all":
         | 
| 802 | 
            +
                        market_times = self._market_times
         | 
| 803 | 
            +
             | 
| 717 804 | 
             
                    _adj_others = force_special_times is True
         | 
| 718 805 | 
             
                    _adj_col = force_special_times is not None
         | 
| 719 806 | 
             
                    _open_adj = _close_adj = []
         | 
| 720 807 |  | 
| 721 808 | 
             
                    schedule = pd.DataFrame()
         | 
| 722 809 | 
             
                    for market_time in market_times:
         | 
| 723 | 
            -
                        temp = self.days_at_time( | 
| 810 | 
            +
                        temp = self.days_at_time(days, market_time).copy()  # standard times
         | 
| 724 811 | 
             
                        if _adj_col:
         | 
| 725 812 | 
             
                            # create an array of special times
         | 
| 726 813 | 
             
                            special = self.special_dates(
         | 
| 727 | 
            -
                                market_time,  | 
| 814 | 
            +
                                market_time, days[0], days[-1], filter_holidays=False
         | 
| 728 815 | 
             
                            )
         | 
| 729 816 | 
             
                            # overwrite standard times
         | 
| 730 817 | 
             
                            specialix = special.index[
         | 
| @@ -740,15 +827,26 @@ class MarketCalendar(metaclass=MarketCalendarMeta): | |
| 740 827 |  | 
| 741 828 | 
             
                        schedule[market_time] = temp
         | 
| 742 829 |  | 
| 743 | 
            -
                     | 
| 744 | 
            -
             | 
| 745 | 
            -
             | 
| 746 | 
            -
             | 
| 830 | 
            +
                    cols = schedule.columns
         | 
| 831 | 
            +
                    if _adj_others and len(_open_adj) > 0:
         | 
| 832 | 
            +
                        mkt_open_ind = cols.get_loc("market_open")
         | 
| 833 | 
            +
             | 
| 834 | 
            +
                        # Can't use Lambdas here since numpy array assignment doesn't return the array.
         | 
| 835 | 
            +
                        def adjust_opens(x):  # x is an np.Array.
         | 
| 836 | 
            +
                            x[x <= x[mkt_open_ind]] = x[mkt_open_ind]
         | 
| 837 | 
            +
                            return x
         | 
| 838 | 
            +
             | 
| 839 | 
            +
                        adjusted = schedule.loc[_open_adj].apply(adjust_opens, axis=1, raw=True)
         | 
| 747 840 | 
             
                        schedule.loc[_open_adj] = adjusted
         | 
| 748 841 |  | 
| 749 | 
            -
             | 
| 750 | 
            -
             | 
| 751 | 
            -
             | 
| 842 | 
            +
                    if _adj_others and len(_close_adj) > 0:
         | 
| 843 | 
            +
                        mkt_close_ind = cols.get_loc("market_close")
         | 
| 844 | 
            +
             | 
| 845 | 
            +
                        def adjust_closes(x):
         | 
| 846 | 
            +
                            x[x >= x[mkt_close_ind]] = x[mkt_close_ind]
         | 
| 847 | 
            +
                            return x
         | 
| 848 | 
            +
             | 
| 849 | 
            +
                        adjusted = schedule.loc[_close_adj].apply(adjust_closes, axis=1, raw=True)
         | 
| 752 850 | 
             
                        schedule.loc[_close_adj] = adjusted
         | 
| 753 851 |  | 
| 754 852 | 
             
                    if interruptions:
         | 
| @@ -761,6 +859,66 @@ class MarketCalendar(metaclass=MarketCalendarMeta): | |
| 761 859 |  | 
| 762 860 | 
             
                    return schedule
         | 
| 763 861 |  | 
| 862 | 
            +
                def date_range_htf(
         | 
| 863 | 
            +
                    self,
         | 
| 864 | 
            +
                    frequency: Union[str, pd.Timedelta, int, float],
         | 
| 865 | 
            +
                    start: Union[str, pd.Timestamp, int, float, None] = None,
         | 
| 866 | 
            +
                    end: Union[str, pd.Timestamp, int, float, None] = None,
         | 
| 867 | 
            +
                    periods: Union[int, None] = None,
         | 
| 868 | 
            +
                    closed: Union[Literal["left", "right"], None] = "right",
         | 
| 869 | 
            +
                    *,
         | 
| 870 | 
            +
                    day_anchor: u.Day_Anchor = "SUN",
         | 
| 871 | 
            +
                    month_anchor: u.Month_Anchor = "JAN",
         | 
| 872 | 
            +
                ) -> pd.DatetimeIndex:
         | 
| 873 | 
            +
                    """
         | 
| 874 | 
            +
                    Returns a Normalized DatetimeIndex from the start-date to End-Date for Time periods of 1D and Higher.
         | 
| 875 | 
            +
             | 
| 876 | 
            +
                    PARAMETERS:
         | 
| 877 | 
            +
             | 
| 878 | 
            +
                    :param frequency: String, Int/float (POSIX seconds) or pd.Timedelta of the desired frequency.
         | 
| 879 | 
            +
                        :Must be Greater than '1D' and an integer multiple of the base frequency (D, W, M, Q, or Y)
         | 
| 880 | 
            +
                        :Important Note: Ints/Floats & Timedeltas are always considered as 'Open Business Days',
         | 
| 881 | 
            +
                            '2D' == Every Other Buisness Day, '3D' == Every 3rd B.Day, '7D' == Every 7th B.Day
         | 
| 882 | 
            +
                        :Higher periods (passed as strings) align to the beginning or end of the relevant period
         | 
| 883 | 
            +
                        :i.e. '1W' == First/[Last] Trading Day of each Week, '1Q' == First/[Last] Day of every Quarter
         | 
| 884 | 
            +
             | 
| 885 | 
            +
                    :param start: String, Int/float (POSIX seconds) or pd.Timestamp of the desired start time.
         | 
| 886 | 
            +
                        :The Time & Timezone information is ignored. Only the Normalized Day is considered.
         | 
| 887 | 
            +
             | 
| 888 | 
            +
                    :param end: String, Int/float (POSIX seconds) or pd.Timestamp of the desired start time.
         | 
| 889 | 
            +
                        :The Time & Timezone information is ignored. Only the Normalized Day is considered.
         | 
| 890 | 
            +
             | 
| 891 | 
            +
                    :param periods: Optional Integer number of periods to return. If a Period count, Start time,
         | 
| 892 | 
            +
                        and End time are given the period count is ignored.
         | 
| 893 | 
            +
             | 
| 894 | 
            +
                    :param closed: Literal['left', 'right']. Method used to close each range.
         | 
| 895 | 
            +
                        :Left: First open trading day of the Session is returned (e.g. First Open Day of The Month)
         | 
| 896 | 
            +
                        :right: Last open trading day of the Session is returned (e.g. Last Open Day of The Month)
         | 
| 897 | 
            +
                        :Note, This has no effect when the desired frequency is a number of days.
         | 
| 898 | 
            +
             | 
| 899 | 
            +
                    :param day_anchor: Day to Anchor the start of the Weekly timeframes to. Default 'SUN'.
         | 
| 900 | 
            +
                        : To get the First/Last Days of the trading Week then the Anchor needs to be on a day the relevant
         | 
| 901 | 
            +
                            market is closed.
         | 
| 902 | 
            +
                        : This can be set so that a specific day each week is returned.
         | 
| 903 | 
            +
                        : freq='1W' & day_anchor='WED' Will return Every 'WED' when the market is open, and nearest day
         | 
| 904 | 
            +
                            to the left or right (based on 'closed') when the market is closed.
         | 
| 905 | 
            +
                        Options: ["SUN", "MON", "TUE", "WED", "THU", "FRI", "SAT"]
         | 
| 906 | 
            +
             | 
| 907 | 
            +
                    :param month_anchor: Month to Anchor the start of the year to for Quarter and yearly timeframes.
         | 
| 908 | 
            +
                        : Default 'JAN' for Calendar Quarters/Years. Can be set to 'JUL' to return Fiscal Years
         | 
| 909 | 
            +
                        Options: ["JAN", "FEB", "MAR", "APR", "MAY", "JUN", "JUL", "AUG", "SEP", "OCT", "NOV", "DEC"]
         | 
| 910 | 
            +
                    """
         | 
| 911 | 
            +
                    return u.date_range_htf(
         | 
| 912 | 
            +
                        self.holidays(),
         | 
| 913 | 
            +
                        frequency,
         | 
| 914 | 
            +
                        start,
         | 
| 915 | 
            +
                        end,
         | 
| 916 | 
            +
                        periods,
         | 
| 917 | 
            +
                        closed,
         | 
| 918 | 
            +
                        day_anchor=day_anchor,
         | 
| 919 | 
            +
                        month_anchor=month_anchor,
         | 
| 920 | 
            +
                    )
         | 
| 921 | 
            +
             | 
| 764 922 | 
             
                def open_at_time(self, schedule, timestamp, include_close=False, only_rth=False):
         | 
| 765 923 | 
             
                    """
         | 
| 766 924 | 
             
                    Determine if a given timestamp is during an open time for the market. If the timestamp is
         | 
| @@ -812,7 +970,11 @@ class MarketCalendar(metaclass=MarketCalendarMeta): | |
| 812 970 |  | 
| 813 971 | 
             
                    # When post follows market_close, market_close should not be considered a close
         | 
| 814 972 | 
             
                    day.loc[day.eq("market_close") & day.shift(-1).eq("post")] = "market_open"
         | 
| 815 | 
            -
                    day = day. | 
| 973 | 
            +
                    day = day.map(
         | 
| 974 | 
            +
                        lambda x: (
         | 
| 975 | 
            +
                            self.open_close_map.get(x) if x in self.open_close_map.keys() else x
         | 
| 976 | 
            +
                        )
         | 
| 977 | 
            +
                    )
         | 
| 816 978 |  | 
| 817 979 | 
             
                    if include_close:
         | 
| 818 980 | 
             
                        below = day.index < timestamp
         | 
    
        {pandas_market_calendars-4.4.0.dist-info → pandas_market_calendars-4.6.0.dist-info}/METADATA
    RENAMED
    
    | @@ -1,6 +1,6 @@ | |
| 1 | 
            -
            Metadata-Version: 2. | 
| 1 | 
            +
            Metadata-Version: 2.2
         | 
| 2 2 | 
             
            Name: pandas_market_calendars
         | 
| 3 | 
            -
            Version: 4. | 
| 3 | 
            +
            Version: 4.6.0
         | 
| 4 4 | 
             
            Summary: Market and exchange trading calendars for pandas
         | 
| 5 5 | 
             
            Author-email: Ryan Sheftel <rsheftel@alumni.upenn.edu>
         | 
| 6 6 | 
             
            License: MIT
         | 
| @@ -18,18 +18,20 @@ Classifier: Programming Language :: Python :: 3.9 | |
| 18 18 | 
             
            Classifier: Programming Language :: Python :: 3.10
         | 
| 19 19 | 
             
            Classifier: Programming Language :: Python :: 3.11
         | 
| 20 20 | 
             
            Classifier: Programming Language :: Python :: 3.12
         | 
| 21 | 
            -
             | 
| 21 | 
            +
            Classifier: Programming Language :: Python :: 3.13
         | 
| 22 | 
            +
            Requires-Python: >=3.8
         | 
| 22 23 | 
             
            Description-Content-Type: text/x-rst
         | 
| 23 24 | 
             
            License-File: LICENSE
         | 
| 24 25 | 
             
            License-File: NOTICE
         | 
| 25 | 
            -
            Requires-Dist: pandas | 
| 26 | 
            +
            Requires-Dist: pandas>=1.1
         | 
| 26 27 | 
             
            Requires-Dist: pytz
         | 
| 27 28 | 
             
            Requires-Dist: python-dateutil
         | 
| 28 | 
            -
            Requires-Dist: exchange-calendars | 
| 29 | 
            +
            Requires-Dist: exchange-calendars>=3.3
         | 
| 29 30 | 
             
            Provides-Extra: dev
         | 
| 30 | 
            -
            Requires-Dist: pytest | 
| 31 | 
            -
            Requires-Dist: black | 
| 32 | 
            -
            Requires-Dist: pre-commit | 
| 31 | 
            +
            Requires-Dist: pytest; extra == "dev"
         | 
| 32 | 
            +
            Requires-Dist: black; extra == "dev"
         | 
| 33 | 
            +
            Requires-Dist: pre-commit; extra == "dev"
         | 
| 34 | 
            +
            Requires-Dist: build; extra == "dev"
         | 
| 33 35 |  | 
| 34 36 | 
             
            pandas_market_calendars
         | 
| 35 37 | 
             
            =======================
         | 
| @@ -196,4 +198,6 @@ Sponsor | |
| 196 198 | 
             
                :target: https://www.tradinghours.com/data
         | 
| 197 199 | 
             
                :alt: TradingHours.com
         | 
| 198 200 |  | 
| 199 | 
            -
            `TradingHours.com <https://www.tradinghours.com>`_ provides the most accurate and comprehensive coverage of market holidays and trading hours data available. They cover over  | 
| 201 | 
            +
            `TradingHours.com <https://www.tradinghours.com?utm_source=github&utm_medium=sponsor&utm_campaign=panda>`_ provides the most accurate and comprehensive coverage of market holidays and trading hours data available. They cover over 1,100 markets worldwide, with extensive historical data and full coverage of all global trading venues, including the CME, ICE, Eurex, and more.
         | 
| 202 | 
            +
             | 
| 203 | 
            +
            Their data is continuously monitored for changes and updated daily. If there's a market you need that they don't currently cover, they'll add it. For when accurate, reliable data matters most, choose TradingHours.com. `Learn more <https://www.tradinghours.com/data?utm_source=github&utm_medium=sponsor&utm_campaign=panda>`_
         | 
| @@ -1,50 +1,50 @@ | |
| 1 | 
            -
            pandas_market_calendars/__init__.py,sha256= | 
| 2 | 
            -
            pandas_market_calendars/calendar_registry.py,sha256= | 
| 3 | 
            -
            pandas_market_calendars/calendar_utils.py,sha256= | 
| 1 | 
            +
            pandas_market_calendars/__init__.py,sha256=9nFwO1i8mOeM9V75vRmbHCz4pcjSjfXHl8CBvrM-_2s,1357
         | 
| 2 | 
            +
            pandas_market_calendars/calendar_registry.py,sha256=9ecKkERkztiwVaOXVsWfUcEvaT5_SwwpD5VaUAJhR1Y,2495
         | 
| 3 | 
            +
            pandas_market_calendars/calendar_utils.py,sha256=f63aNk3Y1RdZhgMhESaCZkCxsOFxJHyq8Hn8C9IrD1w,52360
         | 
| 4 4 | 
             
            pandas_market_calendars/class_registry.py,sha256=lpRSp1E_1vcY73a--daCIOsJpoxpJVuhlurRGDVUqlc,3868
         | 
| 5 | 
            -
            pandas_market_calendars/market_calendar.py,sha256= | 
| 5 | 
            +
            pandas_market_calendars/market_calendar.py,sha256=8h1EamEX0byTNSOZLotg_DboJkwxESghd5J1yMdKLlU,41134
         | 
| 6 6 | 
             
            pandas_market_calendars/calendars/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
         | 
| 7 7 | 
             
            pandas_market_calendars/calendars/asx.py,sha256=tocL_VXzbPNx89mmtXmSw7FKHy2Hzlj5HxcYjfJSn6w,1789
         | 
| 8 8 | 
             
            pandas_market_calendars/calendars/bmf.py,sha256=eyCFpG-ziuI862V5E41PFQw5cD3cOvmgnlAqcYuk9r4,5939
         | 
| 9 9 | 
             
            pandas_market_calendars/calendars/bse.py,sha256=mclRAAK5AvF9vyuIos1PexO0Z3d45ZolrPALVdcSoj0,16947
         | 
| 10 10 | 
             
            pandas_market_calendars/calendars/cboe.py,sha256=tRfq1hiOU2LpEAk-8OC5difM2qLjxNDDpkgobTQtcVI,3765
         | 
| 11 | 
            -
            pandas_market_calendars/calendars/cme.py,sha256= | 
| 12 | 
            -
            pandas_market_calendars/calendars/cme_globex_agriculture.py,sha256= | 
| 11 | 
            +
            pandas_market_calendars/calendars/cme.py,sha256=YJH58ztmnKiyZZ7z2CK4pcvBLOQtflZcUFn1m3o5aLA,10450
         | 
| 12 | 
            +
            pandas_market_calendars/calendars/cme_globex_agriculture.py,sha256=j1Dyg1Q_i3fh4452OeFa5Jw55FW0dhdjmPkmjP85KPc,4666
         | 
| 13 13 | 
             
            pandas_market_calendars/calendars/cme_globex_base.py,sha256=0mvilo9TY5O5EVHNQVNcI8TGycKM5-ymsIcZ4a-ANhU,3062
         | 
| 14 14 | 
             
            pandas_market_calendars/calendars/cme_globex_crypto.py,sha256=HbjTTN8pt2dGfgnE3LS0LIzJlaenYAzilvN9AMwkbfc,5463
         | 
| 15 15 | 
             
            pandas_market_calendars/calendars/cme_globex_energy_and_metals.py,sha256=lcd09CIfZMaZ-mXrI-6c7bqgPx8tj6-2yCOG-f2Hlu4,6620
         | 
| 16 16 | 
             
            pandas_market_calendars/calendars/cme_globex_equities.py,sha256=FMgBDPdamDAgcslQuf-BDUACCQDoYzV4lIbixNLOO-w,3639
         | 
| 17 17 | 
             
            pandas_market_calendars/calendars/cme_globex_fixed_income.py,sha256=egxw-OKUI-SPbNjsLquqPDWQIVX94-torkAuzW6a0aA,4287
         | 
| 18 18 | 
             
            pandas_market_calendars/calendars/cme_globex_fx.py,sha256=lZJpZvKWC9kGcHVjUSG69vH82VwiifLYt1rAlZsDVaM,3206
         | 
| 19 | 
            -
            pandas_market_calendars/calendars/eurex.py,sha256= | 
| 19 | 
            +
            pandas_market_calendars/calendars/eurex.py,sha256=h9K0kvLggc50MKjGb61gfepuiyKovD2uPHCLBruvcBU,2677
         | 
| 20 20 | 
             
            pandas_market_calendars/calendars/eurex_fixed_income.py,sha256=irtSJvCRsn_N2AjjYe5jMvuxblgOx1BTQW2C34RGFlg,2132
         | 
| 21 | 
            -
            pandas_market_calendars/calendars/hkex.py,sha256= | 
| 21 | 
            +
            pandas_market_calendars/calendars/hkex.py,sha256=dQj4roWPLxcxcMaYC9WBaFaHcqsXPdozTufF4ByZN-A,13996
         | 
| 22 22 | 
             
            pandas_market_calendars/calendars/ice.py,sha256=CnlbD3g7L6goukKZtSm-deuCdlB4ZcILTkYbol43TPQ,2159
         | 
| 23 | 
            -
            pandas_market_calendars/calendars/iex.py,sha256= | 
| 24 | 
            -
            pandas_market_calendars/calendars/jpx.py,sha256= | 
| 23 | 
            +
            pandas_market_calendars/calendars/iex.py,sha256=xBqnv_H4GZ0qceSv-yVmKRZRT3F-_UJhIFJBwM1FNO0,4383
         | 
| 24 | 
            +
            pandas_market_calendars/calendars/jpx.py,sha256=uiAtxgXGZAzxM3lxGvVOoIwKvd4gsZTYupTIKoLzn0k,3819
         | 
| 25 25 | 
             
            pandas_market_calendars/calendars/lse.py,sha256=qltdB1TdQ3F8jqx4oykzy_cZvqHlHwnsrpRXzBsovVc,3114
         | 
| 26 | 
            -
            pandas_market_calendars/calendars/mirror.py,sha256= | 
| 27 | 
            -
            pandas_market_calendars/calendars/nyse.py,sha256= | 
| 26 | 
            +
            pandas_market_calendars/calendars/mirror.py,sha256=Oq9jRXYpKmPv6PfoKDVVLyIG7hqcuFFC7fPLcCIhl7k,4555
         | 
| 27 | 
            +
            pandas_market_calendars/calendars/nyse.py,sha256=mQMKGtgiyafGQr69TjvZpnt9f_IjrM5lFk4Rl9T_4do,66012
         | 
| 28 28 | 
             
            pandas_market_calendars/calendars/ose.py,sha256=AfF11QxKYwozaaEc2PvuP3IPvVj5D70mIl0zyp5OogE,2938
         | 
| 29 29 | 
             
            pandas_market_calendars/calendars/sifma.py,sha256=RgOX1yhT8-b6w029ILkOhU-delPCeX6uNWoWDm1Z0eE,9960
         | 
| 30 30 | 
             
            pandas_market_calendars/calendars/six.py,sha256=RYShBBuHg6O5QrMnTmdboInh0Wy5bBNRC9dR-QH9PO8,2610
         | 
| 31 | 
            -
            pandas_market_calendars/calendars/sse.py,sha256= | 
| 32 | 
            -
            pandas_market_calendars/calendars/tase.py,sha256= | 
| 31 | 
            +
            pandas_market_calendars/calendars/sse.py,sha256=o8YUElUPWcqcoMshHMF0mpIaa4GGF2GissrAP47_tbk,10907
         | 
| 32 | 
            +
            pandas_market_calendars/calendars/tase.py,sha256=G0kb-JKgkzwqDLpvUiCgeAXPANETnp3h1U4Vm-9Kj9k,8671
         | 
| 33 33 | 
             
            pandas_market_calendars/calendars/tsx.py,sha256=3zQwdU9LkiJjZRF1fgLGHYYcJMC-443QITVS9hn4kOc,4014
         | 
| 34 34 | 
             
            pandas_market_calendars/holidays/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
         | 
| 35 35 | 
             
            pandas_market_calendars/holidays/cme.py,sha256=TrxR8xA6cgy0YcUfImaKI2QjRmqlwv6pW5KjMKsE1Rg,9089
         | 
| 36 36 | 
             
            pandas_market_calendars/holidays/cme_globex.py,sha256=0SPVGABO7K66eRitDsDgxRU52aPX8SRGgtUVyB_-LYk,5090
         | 
| 37 | 
            -
            pandas_market_calendars/holidays/cn.py,sha256 | 
| 37 | 
            +
            pandas_market_calendars/holidays/cn.py,sha256=-45lLLaGDJZnHMKhOf-RXuHAo7TDBDWdeQ0hRkeMovg,47467
         | 
| 38 38 | 
             
            pandas_market_calendars/holidays/jp.py,sha256=rqobVw837Uxb-4D1Zq_PyBLoeyhImYW7DBwyJupJIp8,9216
         | 
| 39 | 
            -
            pandas_market_calendars/holidays/jpx_equinox.py,sha256= | 
| 40 | 
            -
            pandas_market_calendars/holidays/nyse.py,sha256= | 
| 39 | 
            +
            pandas_market_calendars/holidays/jpx_equinox.py,sha256=KWbJqWsnkdyzG3fD2gJTXRLQOF3YTWSn9O6sYRL9Dnk,8070
         | 
| 40 | 
            +
            pandas_market_calendars/holidays/nyse.py,sha256=jwcz3Xp7NNL0rnwrQG8vuuBuXg7YTSBcg733nmFw-uM,39831
         | 
| 41 41 | 
             
            pandas_market_calendars/holidays/oz.py,sha256=P77pWe7ZQj4o-731w6fW_Vzmo41PRxh94QpclI3ZyFM,1042
         | 
| 42 42 | 
             
            pandas_market_calendars/holidays/sifma.py,sha256=gELES9-NeV3QNGE4JpsVfmcs1-jtYQrLxjnG4B-4RmM,8754
         | 
| 43 43 | 
             
            pandas_market_calendars/holidays/uk.py,sha256=dt5TNONlDMXPw8wjyyPBYNnLO5Yz6Mht8VrPUrNqy-M,4719
         | 
| 44 44 | 
             
            pandas_market_calendars/holidays/us.py,sha256=OBBMMKTRzghD-b9CmPRe5zBh7zQYjWl4-9SogT6ZnBo,11515
         | 
| 45 | 
            -
            pandas_market_calendars-4. | 
| 46 | 
            -
            pandas_market_calendars-4. | 
| 47 | 
            -
            pandas_market_calendars-4. | 
| 48 | 
            -
            pandas_market_calendars-4. | 
| 49 | 
            -
            pandas_market_calendars-4. | 
| 50 | 
            -
            pandas_market_calendars-4. | 
| 45 | 
            +
            pandas_market_calendars-4.6.0.dist-info/LICENSE,sha256=qW51_A-I7YutlB-s8VSKeOP-aL83T-Lb8LqqU1x1ilw,1065
         | 
| 46 | 
            +
            pandas_market_calendars-4.6.0.dist-info/METADATA,sha256=ash0v3KB8sWrQWS0RPCEDGTUfGyDdAU28MdLApcCx6s,9477
         | 
| 47 | 
            +
            pandas_market_calendars-4.6.0.dist-info/NOTICE,sha256=mmH7c9aF5FsELh1OHXloXw1TajLD_mWDKO4dsVf43_E,11693
         | 
| 48 | 
            +
            pandas_market_calendars-4.6.0.dist-info/WHEEL,sha256=In9FTNxeP60KnTkGw7wk6mJPYd_dQSjEZmXdBdMCI-8,91
         | 
| 49 | 
            +
            pandas_market_calendars-4.6.0.dist-info/top_level.txt,sha256=_4cUEFr07SuEAzZMT-5p0lJGXxO9imVbEK9_5oqcopQ,24
         | 
| 50 | 
            +
            pandas_market_calendars-4.6.0.dist-info/RECORD,,
         | 
| 
            File without changes
         | 
| 
            File without changes
         | 
    
        {pandas_market_calendars-4.4.0.dist-info → pandas_market_calendars-4.6.0.dist-info}/top_level.txt
    RENAMED
    
    | 
            File without changes
         |