如何获取对象的方法和属性的完整列表?[重复]
- 2025-03-13 09:23:00
- admin 原创
- 14
问题描述:
dir(re.compile(pattern))
不返回模式作为列表的元素之一。即它返回:
['__copy__', '__deepcopy__', 'findall', 'finditer', 'match', 'scanner', 'search', 'split', 'sub', 'subn']
根据手册,它应该包含
对象的属性名称、其类的属性名称以及其类的基类的属性名称(递归)。
它还说
该列表不一定完整。
有没有办法获取完整列表?我一直以为 dir 会返回完整列表,但显然并非如此……
另外:有没有办法只列出属性?或者只列出方法?
编辑:这实际上是 python 中的一个错误 -> 据称它已在 3.0 分支中修复(也许在 2.6 中也已修复)
解决方案 1:
对于完整的属性列表,简短的回答是:没有。问题在于属性实际上被定义为getattr
内置函数接受的参数。由于用户可以重新实现__getattr__
,突然允许任何类型的属性,因此不可能有通用的方法来生成该列表。该dir
函数返回属性中的键,即如果未重新实现__dict__
该方法,则返回所有可访问的属性。__getattr__
对于第二个问题,这实际上没有任何意义。实际上,方法就是可调用属性,仅此而已。不过,您可以过滤可调用属性,并使用inspect
模块确定类方法、方法或函数。
解决方案 2:
这就是为什么__dir__()
在 Python 2.6 中添加了新方法
看:
解决方案 3:
以下是对 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)
[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
(为简洁起见,删除了测试代码和输出,但基本上对于新式对象,我们似乎对 和 有相同的结果get_object_attrs()
,dir()
而对于旧式类,dir()
输出的主要附加内容似乎是__class__
属性。)
解决方案 4:
仅作补充:
dir()
是最强大/最基本的工具。(最推荐)dir()
除了提供处理输出的方法之外的其他解决方案。dir()
无论是否列出第二级属性,自己进行筛选都很重要,因为有时您可能希望筛选出以下划线开头的内部变量__
,但有时您可能需要__doc__
文档字符串。
__dir__()
并dir()
返回相同的内容。__dict__
和dir()
不同。__dict__
返回不完整的内容。重要提示:
__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)
TypeError:对象描述__dir__
符'object'
需要一个参数
PyTorch 的作者将该__dir__()
方法修改为需要参数的方法。此修改会导致dir()
失败。
如果您想要一个可靠的方案来遍历对象的所有属性,请记住每个 Python 标准都可以被覆盖并且可能不成立,并且每个约定都可能是不可靠的。
解决方案 5:
这是我的做法,对于不断添加属性的简单自定义对象很有用:
给定一个用 创建的对象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}