__getattr__在一个类而不是(或同样)一个实例

时间:2012-07-19 10:43:40

标签: python

我知道我可以编写如下代码:

class A :
    def __getattr__ (self, name) :
        return name

用于捕获对类实例上未定义属性的访问,因此:

A().ATTR == 'ATTR'

True 。但有没有办法为班级本身做这个?我能够做到的是让以下两行都有效,并且可以区分(即,有不同的魔法方法,或魔术方法可以告诉它是如何调用的)

a = A().ATTR
b = A.ATTR

我怀疑答案是没有,但也许有一些深度的python ju-ju?

编辑:实际问题是以向后兼容的方式扩展自定义活动记录库。 ORM代码支持

行的代码
ar = AR_people()
ar.find()
name = ar.name

访问表格,其中name可能会映射到不同的列名称,例如pe_name。我们希望能够写出类似

的内容
ar.filter(AR_people.age >= 21)

并以

结束
pe_age >= 21

(就像其他ORM库一样),因此AR_people.age需要返回一个实现__ge__的类的实例,以此类推,以进行转换魔术。

2 个答案:

答案 0 :(得分:7)

您可以使用metaclass

In [1]: class meta(type):
   ...:     def __getattr__(self, name):
   ...:         return name
   ...:     
   ...:     

In [2]: class A(object):
   ...:     __metaclass__ = meta
   ...:     def __getattr__(self, name):
   ...:         return name
   ...:     
   ...:     

In [3]: A().attr
Out[3]: 'attr'

In [4]: A.attr
Out[4]: 'attr'

答案 1 :(得分:2)

是的,你可以。元类就是答案。

class MyMetaclass(type):
    def __getattr__(cls, name):
        return "cls.%s" % name


class A :
    __metaclass__ = MyMetaclass
    def __getattr__ (self, name) :
        return name

print A().ATTR
print A.ATTR

将输出

ATTR
cls.ATTR