相关疑难解决方法(0)

从str或int继承

为什么我在创建一个继承自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__?为什么?

python string int inheritance new-operator

47
推荐指数
5
解决办法
2万
查看次数

在Python中自定义不可变类型

假设我想要一个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__被寻求时,它们都没有真正起作用.我想这里的特殊方法太特别了.我目前唯一的解决方案是手动委派我能想到的每一种特殊方法,但肯定必须有更好的方法.有任何想法吗?

python delegation immutability

5
推荐指数
1
解决办法
69
查看次数