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

How to implement __delitem__ to handle all possible slice scenarios?(如何实现__delitem__来处理所有可能的切片场景?)

本文介绍了如何实现__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__接收到无法转换为索引的非切片对象时获得早期异常。

这篇关于如何实现__delitem__来处理所有可能的切片场景?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本文标题为:如何实现__delitem__来处理所有可能的切片场景?

基础教程推荐