从输入扩展 FrozenSet
Extending FrozenSet from typing
我可能在这里做了一些愚蠢的事情。对于那些想要复制和粘贴的人,请确保:
from typing import *
我正在使用 Python 3.7.4。
这个:
class S(FrozenSet[str]):
def __init__(self, strs: Iterable[str], name: str):
super().__init__(strs)
self.name = name
S(['a'], 'a')
引发错误:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: S expected at most 1 arguments, got 2
,但是这个:
class S(Set[str]):
def __init__(self, strs: Iterable[str], name: str):
super().__init__(strs)
self.name = name
S(['a'], 'a')
输出很好:
S({'a'})
我想要一套的额外功能,但我不希望我的用户更改它。
编辑:我知道我可以只使用组合而不是继承,但如果我也能做到这一点就好了。
由于是frozenset,一旦创建,内容将无法修改。
因此,我认为您应该覆盖 __new__
:
class S(FrozenSet[str]):
def __new__(cls, strs: Iterable[str], name: str):
return super(S, cls).__new__(cls, strs)
def __init__(self, strs: Iterable[str], name: str):
self.name = name
我可能在这里做了一些愚蠢的事情。对于那些想要复制和粘贴的人,请确保:
from typing import *
我正在使用 Python 3.7.4。
这个:
class S(FrozenSet[str]):
def __init__(self, strs: Iterable[str], name: str):
super().__init__(strs)
self.name = name
S(['a'], 'a')
引发错误:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: S expected at most 1 arguments, got 2
,但是这个:
class S(Set[str]):
def __init__(self, strs: Iterable[str], name: str):
super().__init__(strs)
self.name = name
S(['a'], 'a')
输出很好:
S({'a'})
我想要一套的额外功能,但我不希望我的用户更改它。
编辑:我知道我可以只使用组合而不是继承,但如果我也能做到这一点就好了。
由于是frozenset,一旦创建,内容将无法修改。
因此,我认为您应该覆盖 __new__
:
class S(FrozenSet[str]):
def __new__(cls, strs: Iterable[str], name: str):
return super(S, cls).__new__(cls, strs)
def __init__(self, strs: Iterable[str], name: str):
self.name = name