为什么我在创建一个继承自str(或者也来自int)的类时遇到问题
class C(str):
def __init__(self, a, b):
str.__init__(self,a)
self.b = b
C("a", "B")
TypeError: str() takes at most 1 argument (2 given)
Run Code Online (Sandbox Code Playgroud)
如果我尝试使用int而不是str,它会发生同样的情况,但它适用于自定义类.我需要用__new__而不是__init__?为什么?
假设我想要一个frozenset带有2个元素的自定义,迭代,散列,比较,并具有各种其他不错的操作作为冻结集,但打印方式不同.
>>> p = edge(5, 7)
>>> p == edge(7, 5)
True
>>> p
edge(5, 7)
Run Code Online (Sandbox Code Playgroud)
我可以继承,或者我可以委托,但在任何情况下我都得不到我想要的.
如果我从字面上继承,似乎没有办法可以写__init__,因为我的父母是不可变的.我可以写:
class edge:
def __new__(cls, a, b):
return frozenset({a, b})
Run Code Online (Sandbox Code Playgroud)
但后来我得到了一个合适的冷冻集,无法自定义它__repr__,这就是我想要做的.我不能super()以任何好的方式在这里工作.
如果我委托,我可以覆盖__getattr__或__getattribute__,但是当例如__iter__被寻求时,它们都没有真正起作用.我想这里的特殊方法太特别了.我目前唯一的解决方案是手动委派我能想到的每一种特殊方法,但肯定必须有更好的方法.有任何想法吗?