动态创建类属性

汤米:

我正在寻找一种动态创建具有可通过典型实例符号访问的特定属性的类的方法。

       DynoOne = createClass('DynoOne',props=['A','B'])
       d = DynoOne (database='XYZ')
       d.A = d.B + 1

       DynoTwo = createClass('DynoTwo',props=['A','C','E'])
       q = DynoTwo (database='QRS')
       q.A = q.C + 2*q.E

实际如何获取和修改“道具”的细节将被隐藏。当新道具可用时,这也使添加新道具的访问变得更加容易。

我已经尝试了以下技术,以了解python如何动态产生基本的类属性:

类工厂产生简单的类结构类?

我最初对python的阅读表明,类属性是处理引入getter / setter方法进行访问的一种方法。

尚不清楚如何在工厂构造函数方法中动态指定属性名称(无论使用装饰器还是显式的property()调用)

例如,使用property()。

   class DynamicClass( someBase ):

       def dynamic_getter(self):
           # acquire "stuff"
           return stuff

       def dynamic_setter(self,stuff):
           # store  "stuff"
           pass 

       dynamic_property_name = property(fget=dynamic_getter,fset=dynamic_setter)

当类被声明/构造时,我需要为每个请求的道具创建一个集合。例如,DynoOne类将为“ A”和“ B”具有单独的属性/设置器/获取器。

我怀疑基于模板的eval()策略会起作用,但是我可能会缺少一些更基本和有效的技术。

启发和学习机会受到赞赏:-)

juanpa.arrivillaga:

的三个参数type可让您动态创建类。因此,一个草图:

def dynamic_getter(self):
    # acquire "stuff"
    return stuff

def dynamic_setter(self,stuff):
    # store  "stuff"
    pass 

DynamicClass =  type('DynamicClass', (SomeBase,), {"dynamic_property_name":property(fget=dynamic_getter,fset=dynamic_setter)})

或者,更具体地说:

In [1]: class SomeBase:
   ...:     def __init__(self):
   ...:         self._foo = 42
   ...:
   ...: def dynamic_getter(self):
   ...:     # acquire "stuff"
   ...:     return self._foo
   ...:
   ...: def dynamic_setter(self,stuff):
   ...:     # store  "stuff"
   ...:     pass
   ...:
   ...: DynamicClass =  type('DynamicClass', (SomeBase,), {"dynamic_property_name":property(fget=dynamic_getter,fset=dynamic_setter)})

In [2]: instance = DynamicClass()

In [3]: instance.dynamic_property_name
Out[3]: 42

注意:type从字面上看,它是一个类对象,以其他三个参数形式调用它是新类对象实例的构造函数,它是创建其他类对象的类,即元类。实际上,您可以将类定义语句视为上述的语法糖。

基于模板的使用exec(如果你想用一个复杂的语句,你需要execeval只允许表达式)的做法是可行的也是,如果你发现更易于使用。确实,这就是collections.namedtuple标准库中的工作方式。

注意:您似乎对Python属性的性质感到困惑。没有在类上指定实例属性,相反,您将添加一个函数来初始化那些实例属性(通常是__init__),但是您可以在任何位置(甚至在方法/类之外)添加实例属性

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章