Подклассы datetime64

Как я могу создать подкласс от NumPy DateTime64? Например, используя стандартную дату и время, я могу легко создать подкласс:

import datetime as dt

class SubFromDateTime(dt.datetime):
    def __new__(self):
        return dt.datetime.__new__(self, 2012, 1, 1)

print type(SubFromDateTime())

>>> 
<class '__main__.SubFromDateTime'>

Однако, используя datetime64, следующее всегда возвращает ссылку на datetime64, а не мой класс...

from numpy import datetime64

class SubFromDT64(datetime64):
    def __new__(self):
        return datetime64.__new__(self, '20120101')

print type(SubFromDT64())

>>>
<type 'numpy.datetime64'>

Как я могу это исправить? В основном я хотел бы написать простую оболочку для datetime64, которая позволяет мне добавлять пользовательские функции, такие как получение месяца заданной даты с помощью простого метода.Month (). В верхнем примере я могу легко добавить методы, в нижнем примере он никогда не распознает мои методы и думает, что это объект datetime64.

1 ответ

Я закончил подклассом ndarray, который создает массив datetime64. Работает как шарм для моих целей. В случае, если кто-то заинтересован здесь код:

import numpy as np

class Date64(np.ndarray):
    def __new__(cls, data):
        data = np.asarray(data, dtype='datetime64')
        if (data.dtype != 'datetime64[D]'):
            raise Exception('Unable to parse dates adequately to datetime64[D]: %s' % data)
        obj = data.view(cls)
        return obj

    def Year(self):
        return self.astype('datetime64[Y]').astype(int) + 1970

    def Month(self):
        return self.astype('datetime64[M]').astype(int) % 12 + 1

    def Day(self):
        return (self - self.astype('datetime64[M]') + 1).astype(int)

    def ISO(self):
        if (self.shape):
            out = zip(self.Year(), self.Month(), self.Day())
            iso = [ '%04d-%02d-%02d' % each for each in out ]
        else:
            iso = '%04d-%02d-%02d' % (self.Year(), self.Month(), self.Day())
        return iso

    def Export(self):
        return self

    def __array_finalize__(self, obj):
        if obj is None:
            return


if (__name__ == '__main__'):
    a = [ dt.date(2013, 1, 1), '2012-03-01', '2012-07-02', '2012-01-03', '2012-01-04', '2011-01-05' ]
    b = Date64(a)

    print b
    print b.ISO()
Другие вопросы по тегам