在这里__class__
不应该与我已经能够通过inspect
模块访问self.__class__
混淆:
import inspect
class A:
def __init__(self):
print(__class__.__name__) # I want to move this statement inside f
f()
class B(A):
pass
def f():
prev_frame = inspect.currentframe().f_back
self = prev_frame.f_locals["self"]
print(self.__class__.__name__)
B() # prints A B
仅
当您在方法中实际引用隐式__class__
引用(或使用 super
时,才会在编译时创建隐式引用。例如,此代码:
class Foo:
def bar(self):
print('bar', locals())
def baz(self):
print('baz', locals())
if False:
__class__
if __name__ == '__main__':
foo = Foo()
foo.bar()
foo.baz()
生成以下输出:
bar {'self': <__main__.Foo object at 0x10f45f978>}
baz {'self': <__main__.Foo object at 0x10f45f978>, '__class__': <class '__main__.Foo'>}
要查找调用函数的类(在大多数情况下(,您可以将一些特定于 CPython 的inspect
咒语链接在一起:
- 找到调用函数:如何将当前函数放入变量中?
- 查找该函数的类:获取 Python 3 中未绑定方法对象的定义类
我不会推荐它。