[英]Inherit Tuple in python - ordered tuple
我想创建一个类:
tuple
相同的行为:
__len__
, index
, __getitem__
等等floats
并且是有序的qtmin
计算有多少元素等于最小值所以,我的想法是继承tuple
的类。
class MyTuple(tuple):
@staticmethod
def VerifyIsOrdered(U: tuple[float]):
n = len(U)
for i in range(n-1):
if U[i] > U[i+1]:
raise ValueError("U must be ordered")
def __init__(self, U: tuple[float]):
MyTuple.VerifyIsOrdered(U)
super().__init__(U)
@property
def qtmin(self):
minU = min(self)
for i in range(len(self)):
if self[i] != minU:
return i
MyTuple([0, 1, 2, 3]) # qtmin = 1
MyTuple([0, 0, 0, 1, 2, 3]) # qtmin = 3
但是我在super().__init__(U)
行收到以下错误
TypeError: object.__init__() takes exactly one argument (the instance to initialize)
但我不明白有什么问题,因为当我调用super
时,它意味着初始化原始tuple
。 我该如何解决?
tuple
是不可变的,因此您需要使用__new__
而不是__init__
。 从文档
new () 主要是为了允许不可变类型(如 int、str 或 tuple)的子类自定义实例创建。 它也通常在自定义元类中被覆盖,以自定义类创建。
def __new__(cls, U: tuple[float]):
MyTuple.VerifyIsOrdered(U)
return super(MyTuple, cls).__new__(cls, tuple(U))
为了获得更好的语法,您可以像这样使用解包:
def __new__(cls,*U):
MyTuple.VerifyIsOrdered(U)
return super(MyTuple,cls).__new__(cls,U)
所以你可以写:
MyTuple(0, 1, 2, 3)
代替
MyTuple([0, 1, 2, 3])
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.