如何实现__delitem__来处理所有可能的切片场景?
问题描述
我使用具有和嵌入列表的类。
class a:
def __init__(self, n):
self.l = [1] * n
def __getitem__(self, i):
return self.l[i]
def __delitem__(self, i):
print type(i)
print i
我要将del
运算符与切片的完整语法一起使用:
p = a(10)
del p[1:5:2]
如果__delitem__
参数不是单个索引,则__delitem__
接收slice
对象。如何使用slice
对象循环访问指定的元素?
解决方案
切片对象的indices
方法将在给定序列长度的情况下提供您可以馈送到xrange
的切片的规范解释:
def __delitem__(self, item):
if isinstance(item, slice):
for i in xrange(*item.indices(len(self.l))):
print i
else:
print operator.index(item)
使用slice.indices
可确保在Dunes指出的情况下获得正确的行为。还要注意,您可以将切片对象传递给list.__delitem__
,因此如果您只需要进行一些预处理并将实际删除委托给底层列表,那么"naive"del self.l[i]
实际上会正常工作。
operator.index
将确保您在__delitem__
接收到无法转换为索引的非切片对象时获得早期异常。
相关文章