我知道我可以编写如下代码:
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__
的类的实例,以此类推,以进行转换魔术。
答案 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