我正在尝试创建一个具有类似于列表的属性的对象。这就是我的意思。
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/