-1

我想写一个继承地图类的自定义类。

class mapT(map):
def __init__(self,iii):
    self.obj = iii

但我无法初始化它。

# Example init object
ex = map(None,["","1","2"])

exp1 = mapT(ex)
# TypeError: map() must have at least two arguments.

exp1 = mapT(None,ex)
# TypeError: __init__() takes 2 positional arguments but 3 were given

如何在python中创建一个继承地图的类?或者为什么我不能在 python 中继承地图?

===== 添加 =====

我想要实现的是为可迭代对象添加自定义方法

def iterZ(self_obj):
    class iterC(type(self_obj)):
        def __init__(self,self_obj):
            super(iterC, self).__init__(self_obj)
            self.obj = self_obj
        def map(self,func):
            return iterZ(list(map(func,self.obj))) # I want to remove "list" here, but I can't. Otherwise it cause TypeError
        def filter(self,func):
            return iterZ(list(filter(func,self.obj))) # I want to remove "list" here, but I can't. Otherwise it cause TypeError
        def list(self):
            return iterZ(list(self.obj))
        def join(self,Jstr):
            return Jstr.join(self)
return iterC(self_obj)

这样我就可以做到这一点:

a = iterZ([1,3,5,7,9,100])
a.map(lambda x:x+65).filter(lambda x:x<=90).map(lambda x:chr(x)).join("")
# BDFHJ

而不是这个:

"".join(map(lambda x:chr(x),filter(lambda x:x<=90,map(lambda x:x+65,a))))
4

1 回答 1

2

您不应该从要包装的对象继承。那是因为您的 API 与该类型不同,并且没有好的方法可以确保您可以正确构建该类的新实例。您的map情况就是一个例子,您__init__期望的参数数量与实际不同map.__new__,并且没有很好的方法来合理化它们。

而不是从类继承,只是围绕它。这可能会限制可以使用的 API 类型,但您主要关注的是迭代器协议,所以可能__iter__并且__next__您只需要:

class iterZ:
    def __init__(self, iterable):
        self.iterator = iter(iterable)

    def __iter__(self):
        return self

    def __next__(self):
        return next(self.iterator)

    def map(self,func):
        return iterZ(map(func,self.iterator))

    def filter(self,func):
        return iterZ(filter(func,self.iterator))

    def join(self,Jstr):
        return Jstr.join(self.iterator)
于 2020-04-15T08:36:32.057 回答