如何获得对象的方法和属性的完整列表?

dir(re.compile(pattern))

不返回作为列表元素之一的模式。即它返回:

['__copy__', '__deepcopy__', 'findall', 'finditer', 'match', 'scanner', 'search', 'split', 'sub', 'subn']

根据手册,它应该包含

对象的属性名称、 其类属性的名称,以及 属性的递归 类的基类。

上面还说

这个列表不一定完整。

有办法拿到 完整名单吗?我总是假设 dir 返回一个完整的列表,但显然它不..。

还有: 有没有办法只列出属性? 或者只列出方法?

编辑: 这实际上是 python-> 中的一个 bug,据推测它在3.0分支中得到了修复(也可能在2.6中得到了修复)

342872 次浏览

对于完整的属性列表,简单的答案是:no。问题是属性实际上被定义为getattr内置函数接受的参数。由于用户可以重新实现__getattr__,突然允许任何类型的属性,因此没有可能的通用方法来生成该列表。dir函数返回__dict__属性中的键,即,如果__getattr__方法没有重新实现,则所有可访问的属性。

至于第二个问题,其实没有什么意义。实际上,方法是可调用的属性,仅此而已。你可以过滤可调用的属性,并使用inspect模块确定类方法、方法或函数。

这就是为什么在python 2.6中添加了新的__dir__()方法

看到的:

下面是对PierreBdR和Moe的回答的补充:

  • 对于Python >= 2.6和新型类dir()似乎就足够了。
  • 对于老式的类,我们至少可以像标准模块那样支持制表符自动补全:除了dir()之外,查找__class__,然后查找它的__bases__:

    # code borrowed from the rlcompleter module
    # tested under Python 2.6 ( sys.version = '2.6.5 (r265:79063, Apr 16 2010, 13:09:56) \n[GCC 4.4.3]' )
    
    
    # or: from rlcompleter import get_class_members
    def get_class_members(klass):
    ret = dir(klass)
    if hasattr(klass,'__bases__'):
    for base in klass.__bases__:
    ret = ret + get_class_members(base)
    return ret
    
    
    
    
    def uniq( seq ):
    """ the 'set()' way ( use dict when there's no set ) """
    return list(set(seq))
    
    
    
    
    def get_object_attrs( obj ):
    # code borrowed from the rlcompleter module ( see the code for Completer::attr_matches() )
    ret = dir( obj )
    ## if "__builtins__" in ret:
    ##    ret.remove("__builtins__")
    
    
    if hasattr( obj, '__class__'):
    ret.append('__class__')
    ret.extend( get_class_members(obj.__class__) )
    
    
    ret = uniq( ret )
    
    
    return ret
    

(Test code and output are deleted for brevity, but basically for new-style objects we seem to have the same results for get_object_attrs() as for dir(), and for old-style classes the main addition to the dir() output seem to be the __class__ attribute.)

这就是我怎么做的,对你不断添加属性的简单自定义对象很有用:

给定一个用obj = type("Obj",(object,),{})创建的对象,或者简单地通过:

class Obj: pass
obj = Obj()

添加一些属性:

obj.name = 'gary'
obj.age = 32

然后,获取一个只有自定义属性的字典:

{key: value for key, value in obj.__dict__.items() if not key.startswith("__")}


# {'name': 'gary', 'age': 32}

只是补充:

  1. dir()大多数的强大/基本工具。(最推荐的)
  2. dir()以外的解决方案仅提供处理dir()的输出他们的方式

    不管是否列出第二级属性,自己进行筛选是很重要的,因为有时你可能想筛选出前导下划线__的内部变量,但有时你可能很需要__doc__ doc-string.

  3. __dir__()dir()返回相同的内容。
  4. __dict__dir()是不同的。__dict__返回不完整的内容。
  5. 重要的: __dir__()有时可以被作者出于任何目的用函数、值或类型覆盖。

    这里有一个例子:

    \\...\\torchfun.py in traverse(self, mod, search_attributes)
    445             if prefix in traversed_mod_names:
    446                 continue
    447             names = dir(m)
    448             for name in names:
    449                 obj = getattr(m,name)
    

    'object'对象的描述符__dir__需要一个参数

    PyTorch的作者将__dir__()方法修改为需要参数的方法。此修改将导致dir()失败

  6. 如果你想要一个reliable方案遍历对象的所有属性,请记住,每个pythonic标准都可以被覆盖,并且可能不包含,而且每个约定都可能不可靠。