class A:
    def foo(self):
        print "foo()"

getattr(A, foo) # True
A.foo() # error

getattr(A(), foo) # True
A().foo() # prints "foo()"

话虽如此,这是我的问题:

我希望将测试用例元信息存储为测试用例类对象本身的属性,而不是它们的实例。
我有一个要提取的属性名称列表,但是如果存在同名的实例方法,那么 getattr(class_obj, attr) 将返回 True,但 getattr(class_obj, attr)() 会引发错误。

有没有办法告诉 getattr 不包含实例化类的属性,而只包含类对象本身的属性?

编辑:我尝试直接访问 class_obj.__dict__(我认为这是不好的做法),但它不包含一些属性,如 __name__
编辑:改写问题。有没有办法区分 obj 类的方法和类实例的方法?

最佳答案

这够好吗?

import types
class Test(object):
    @staticmethod
    def foo():
        print 'foo'

    def bar(self):
        print 'bar'

结合:
>>>(isinstance(getattr(Test, 'foo'), types.FunctionType),
    isinstance(getattr(Test, 'bar'), types.FunctionType))
True, False

您还可以使用 inspect 模块:
>>> inspect.isfunction(Test.foo)
True
>>> inspect.isfunction(Test.bar)
False

通过一些额外的工作,您甚至可以将类方法与实例方法和静态方法区分开来:
import inspect

def get_type(cls, attr):
    try:
        return [a.kind for a in inspect.classify_class_attrs(cls) if a.name == attr][0]
    except IndexError:
        return None

class Test(object):
    @classmethod
    def foo(cls):
        print 'foo'

    def bar(self):
        print 'bar'

    @staticmethod
    def baz():
        print 'baz'

您可以将其用作:
>>> get_type(Test, 'foo')
'class method'
>>> get_type(Test, 'bar')
'method'
>>> get_type(Test, 'baz')
'static method'
>>> get_type(Test, 'nonexistant')
None

关于python - 类对象上的 getattr,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/18498295/

10-11 06:22