如何实现__delitem__来处理所有可能的切片场景?

时间:2012-10-20 07:43:35

标签: python slice

我在一个带有嵌入式列表的类上工作。

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运算符和slice的完整语法:

p = a(10)
del p[1:5:2]

如果参数不是单个索引,__delitem__会收到slice个对象。如何使用slice对象迭代指定的元素?

2 个答案:

答案 0 :(得分:3)

slice个对象具有startstopstep属性,您可以使用这些属性来获取每个组件。例如:

def __delitem__(self, i):
    if isinstance(i, slice):
        for j in xrange(i.start, i.stop, i.step):
            print j
    else:
        print i

答案 1 :(得分:3)

在给定序列长度的情况下,切片对象的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__,因此,如果您只需要进行一些预处理并将实际删除委托给基础列表,那么“天真”del self.l[i]实际上可以正常工作。 / p> 如果operator.index收到无法转换为索引的非切片对象,

__delitem__将确保您获得早期异常。