我正在尝试创建一个具有类似于列表的属性的对象。这就是我的意思。

class Unit:

    def __init__(self):
        self.val = 0

class Bundle:

    def __init__(self, N=3):
        self.units = [ Unit() for i in range(N) ]

    def getvals(self):
        return [ unit.val for unit in self.units ]

    def setvals(self, vals):
        for i, val in enumerate(vals):
            self.units[i].val = val

    vals = property(getvals, setvals)

现在,这个对象的行为不像预期的那样。
>>> b = Bundle()
>>> b.setvals([1,2,3])
>>> print b.vals, b.getvals()
[1, 2, 3] [1, 2, 3]
>>> b.vals = [4,5,6]
>>> print b.vals, b.getvals()
[4, 5, 6] [1, 2, 3]

所以语句“b.vals = x”和“b.setvals(x)”是不等价的。你能告诉我为什么,以及如何让它表现得正确吗?

最佳答案

在 Python 2 中,property 仅适用于新样式对象;您的 Bundle 类必须继承自 object :

class Bundle(object):
    ...

进行更正后,该属性将按预期工作:
>>> b.vals = [4,5,6]
>>> b.vals
[4, 5, 6]
>>> b.getvals()
[4, 5, 6]
>>> [unit.val for unit in b.units]
[4, 5, 6]

关于python 属性 : list-like object,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/13660346/

10-10 01:22
查看更多