使用同一函数设置多个类属性

2024-04-25 17:16:19 发布

您现在位置:Python中文网/ 问答频道 /正文

我想创建一个python类,其中一些属性是datetime.date类型的,但是也可以使用strdatetime.datetime实例来设置它们。到目前为止,我有:

import datetime


def my_date_fn(date_in):
    """
    Return a datetime.date object from either a string (e.g. "2018/01/04"),
    datetime.datetime or datetime.date object.
    """
    if type(date_in) is str:
        return datetime.date(*map(int, date_in.split('/')))
    elif type(date_in) is datetime.datetime:
        return date_in.date()
    elif type(date_in) is datetime.date:
        return date_in


class MyClass(object):
    """
    Class to contain date information.
    """
    def __init__(self, a, b, c):
        self.a = a
        self.b = b
        self.c = c

    @property
    def a(self):
        return self._a

    @a.setter
    def a(self, value):
        self._a = my_date_fn(value)

    @property
    def b(self):
        return self._b

    @b.setter
    def b(self, value):
        self._b = my_date_fn(value)

    @property
    def c(self):
        return self._c

    @c.setter
    def c(self, value):
        self._c = my_date_fn(value)


test = MyClass('2017/7/7', datetime.date(2012, 8, 4),
               datetime.datetime(2001, 5, 3, 12, 0))

for x in ['a', 'b', 'c']:
    print getattr(test, x), type(getattr(test, x))

这可以很好地工作,但是有很多重复的代码使用@property@*.setter函数。有没有更优雅的方法?你知道吗


Tags: intestselfdatetimedatereturnobjectis
1条回答
网友
1楼 · 发布于 2024-04-25 17:16:19

简单地定义一个函数:

def date_property(name):
    def set_date(self, date_in):
        """
        Return a datetime.date object from either a string (e.g. "2018/01/04"),
        datetime.datetime or datetime.date object.
        """
        if isinstance(date_in, str):
            date_in = datetime.date(*map(int, date_in.split('/')))
        elif isinstance(date_in, datetime.datetime):
            date_in = date_in.date()
        elif isinstance(date_in, datetime.date):
            pass
        else:
            raise TypeError()
        setattr(self, name, date_in)
    return property(lambda self: getattr(self, name), set_date)


class MyClass(object):
    """
    Class to contain date information.
    """
    def __init__(self, a, b, c):
        self.a = a
        self.b = b
        self.c = c

    a = date_property('_a')
    b = date_property('_b')
    c = date_property('_c')

相关问题 更多 >