3

我想做这样的事情

def make_class(name : str)->type:
    class Ret:
       __name__ = name
       def __init__(self):
           self.__x = 0
    return Ret

A = make_class('A')
a = A()
assert a._A__x == 0

基本上,我想要的是创建一个类型,以便它根据动态标识符破坏其成员,但上面的示例不起作用。元类也不行。

我能想到的唯一解决方案是:

执行整个类定义

exec("""
class {}:
    def __init__(self):
        self.__x = 0
""".format(name))

或通过 getattr 设置属性

class Ret:
    def __init__(self):
        setattr(self,'_'+name+"__x",0)

但是由于各种原因,它们都没有吸引力,有没有正确的方法可以做到这一点?

4

1 回答 1

1

Python 名称修改基本上是静态的。它在字节码编译时执行,在您的函数name参数可用之前。要动态调用此机制,您必须动态编译代码,这意味着您必须使用exec或类似的东西。

于 2018-05-17T21:57:06.233 回答