0

我是python的新手。所以如果我写错了,请随时纠正。

我已经创建了一个新类ClassA,它有一个属性modified,它是一个列表。

该类最初看起来像这样:

class ClassA:
        def __init__(self):
            self.modified = []

我希望在此列表中添加(或修改)的元素首先通过检查。例如。我只想要此列表中的日期,其格式为YYYY-MM-DD. 所以我认为@propoerty装饰器可以做一些工作。我以下列方式使用它:

class ClassA:

        def __init__(self):
            self._modified = []

        @property
        def modified(self):
            return getattr(self, "_modified")

        @modified.setter
        def modified(self, value):
            if not isinstance(value, list):
                raise TypeError("value passed must be a list")
            else:
                modified_list = []
                for item in value:
                    if isinstance(item, str):
                        result = performValidationCheck(item)
                        if not result:
                            raise ValueError("date format incorrect")
                        else:
                            modified_list.append(date.getDateAsString())
                    else:
                        raise TypeError("%s must be of type string")
                self._modified = modified_list

        def add_modified_date(self, date):
            if not isinstance(date, str):
                raise TypeError("date passed must be a string")
            result = performValidationCheck(date)
            if not result:
                raise ValueError(libsbml.OperationReturnValue_toString(result))
            self._modified.append(date)

但是,我仍然可以modified使用classA.modified[index]. 甚至附加功能也在这个列表上工作。

我已经实现了这个performValidationCheck()功能,这不是这里关心的问题。

有人可以帮我解决这个问题吗?

4

1 回答 1

1

但是,我仍然可以使用 classA.modified[index] 来更改修改后列表中条目的值。甚至附加函数也在这个列表上工作。但是,我仍然可以使用 classA.modified[index] 来更改修改后列表中条目的值。甚至附加功能也在这个列表上工作。

当然。@property仅控制获取/设置对象的属性。如果在属性上设置的对象是可变的,它就不能做任何事情。

有人可以帮我解决这个问题吗?

要么使用一个自定义的类似列表的集合(一个 MutableSequence)来动态验证它的值,要么使用一个元组(基本上是一个不可变的列表),这样调用者将无法就地修改它。

于 2020-06-04T10:33:26.213 回答