如何打印 Python 属性名称?

How to print a Python attribute name?

假设我想创建一个内省节,它显示函数的可用详细信息。
类似于下面代码的底部:

def sample(_range=4):
    """ produce a range of integers """
    for i in range(_range):
        yield i

f = sample
for i in (f.__name__, f.__doc__, f.__dict__, f.__code__, f.__defaults__, f.__globals__, f.__closure__):
    print("XXX", i)

我未能实现的是将 XXX 更改为可以打印属性名称的内容,例如,而不是

XXX sample
XXX  produce a range of integers
XXX {}
XXX <code object sample at 0xfff15890, file "/tmp/tmp.py", line 1>
XXX (4,)
XXX {'__loader__': <_frozen_importlib.SourceFileLoader object at 0xfff13b30>, '__package__': None, '__file__': '/tmp/tmp.py', '__cached__': None, 'i': {...}, 'f': <function sample at 0xfff5b1e0>, '__builtins__': <module 'builtins' (built-in)>, '__doc__': None, '__spec__': None, '__name__': '__main__', 'sample': <function sample at 0xfff5b1e0>}
XXX None

我想要

__name__ sample
__doc__  produce a range of integers
__dict__ {}
__code__ <code object sample at 0xfff15890, file "/tmp/tmp.py", line 1>
__defaults__ (4,)
f.__globals__ {'__loader__': <_frozen_importlib.SourceFileLoader object at 0xfff13b30>, '__package__': None, '__file__': '/tmp/tmp.py', '__cached__': None, 'i': {...}, 'f': <function sample at 0xfff5b1e0>, '__builtins__': <module 'builtins' (built-in)>, '__doc__': None, '__spec__': None, '__name__': '__main__', 'sample': <function sample at 0xfff5b1e0>}
__closure__ None

您建议用什么来代替 XXX

如果像您的示例一样,您知道所需属性的名称,那么这将起作用:

for fn in ('__name__', '__doc__', '__dict__', '__code__', '__defaults__', '__globals__', '__closure__'):
    print(fn, getattr(f, fn))

如果你问的是如何在只有函数的情况下获取名称,那我相信你运气不好;该名称不是函数的 属性 ,而是它的引用方式,就像您不能仅从数字中询问包含数字 3 的变量的名称一样。 (思考练习:作为 3 个不同对象的一部分的函数的名称是什么,每个对象都具有不同的名称?)

我想,如果您想要特定对象中函数的名称,您可以遍历该对象的属性,搜索您的函数;当您找到它时,您用来引用它的名称就是您想要的名称。

因为您已经有了属性列表,您可以使用 getattr :

for name in ['__name__', '__doc__', '__dict__', '__code__', '__defaults__', '__globals__', '__closure__']:
    print('{} -> {}'.format(name, getattr(f, name)))