3 回答

TA贡献1795条经验 获得超7个赞
对于属性的完整列表,简短的答案是:否。问题在于属性实际上定义为getattr
内置函数接受的参数。由于用户可以重新实现__getattr__
,突然允许任何类型的属性,因此没有可能的通用方法来生成该列表。该dir
函数返回__dict__
属性中的键,即,如果__getattr__
未重新实现该方法,则所有可访问的属性。
对于第二个问题,这没有任何意义。实际上,方法是可调用的属性,仅此而已。但是,您可以过滤可调用的属性,并使用该inspect
模块确定类的方法,方法或函数。

TA贡献1895条经验 获得超3个赞
对于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
(测试代码和输出都被删除了简洁,但基本上对新风格的对象,我们似乎有相同的结果get_object_attrs()为dir(),对于老式类主要除了dir()输出似乎是__class__属性。)
添加回答
举报