Sto provando a creare un calendario di trading usando Pandas. Sono in grado di creare un'istanza cal basata sul USFederalHolidayCalendar. L'USFederalHolidayCalendar non è coerente con il calendario di Trading in quanto il calendario di Trading non include Columbus Day e Veteran's Day. Tuttavia, il calendario delle negoziazioni include il Venerdì Santo (non incluso negli USFederalHolidayCalendar). Tutto tranne per l'ultima riga di codice seguente funziona:Crea un calendario di festività con Pandas
from pandas.tseries.holiday import get_calendar, HolidayCalendarFactory, GoodFriday
from datetime import datetime
cal = get_calendar('USFederalHolidayCalendar') # Create calendar instance
cal.rules.pop(7) # Remove Veteran's Day rule
cal.rules.pop(6) # Remove Columbus Day rule
tradingCal = HolidayCalendarFactory('TradingCalendar', cal, GoodFriday)
L'istanza tradingCal sembra funzionare in che io sono in grado di visualizzare le regole per vacanze.
In[10]: tradingCal.rules
Out[10]:
[Holiday: Labor Day (month=9, day=1, offset=<DateOffset: kwds={'weekday': MO(+1)}>),
Holiday: Presidents Day (month=2, day=1, offset=<DateOffset: kwds={'weekday': MO(+3)}>),
Holiday: Good Friday (month=1, day=1, offset=[<Easter>, <-2 * Days>]),
Holiday: Dr. Martin Luther King Jr. (month=1, day=1, offset=<DateOffset: kwds={'weekday': MO(+3)}>),
Holiday: New Years Day (month=1, day=1, observance=<function nearest_workday at 0x000000000A190BA8>),
Holiday: Thanksgiving (month=11, day=1, offset=<DateOffset: kwds={'weekday': TH(+4)}>),
Holiday: July 4th (month=7, day=4, observance=<function nearest_workday at 0x000000000A190BA8>),
Holiday: Christmas (month=12, day=25, observance=<function nearest_workday at 0x000000000A190BA8>),
Holiday: MemorialDay (month=5, day=31, offset=<DateOffset: kwds={'weekday': MO(-1)}>)]
Quando provo ad elencare le vacanze in un intervallo di date, ho il seguente errore:
In[11]: tradingCal.holidays(datetime(2014, 12, 31), datetime(2016, 12, 31))
Traceback (most recent call last):
File "C:\Python27\lib\site-packages\IPython\core\interactiveshell.py", line 3035, in run_code
exec(code_obj, self.user_global_ns, self.user_ns)
File "<ipython-input-12-2708cd2db7a0>", line 1, in <module>
tradingCal.holidays(datetime(2014, 12, 31), datetime(2016, 12, 31))
TypeError: unbound method holidays() must be called with TradingCalendar instance as first argument (got datetime instance instead)
Tutte le idee?
Perfetto, jezrael. Grazie. – vlmercado
Penso che questo abbia un difetto significativo! L'uso di '.pop' influisce sulla classe sottostante' pandas.tseries.holiday.USFederalHolidayCalendar' perché è un'operazione "sul posto" (non sicura della terminologia). Ciò significa che se provi a ricreare cal2 da get_calendar ('USFederalHolidayCalendar') 'le regole sono le stesse di' cal'. cioè non ottieni una versione * clean * di 'USFederalHolidayCalendar' perché non esiste più, l'hai modificata! – evan54
@ evan54 Ho notato anche questo. hai una soluzione? – WillZ