我不相信,在帧对象级别,有任何方法可以找到已调用的实际python函数对象。
但是,如果代码依赖于公共约定:命名方法self的实例参数,则可以执行以下操作:def get_class_from_frame(fr):
import inspect
args, _, _, value_dict = inspect.getargvalues(fr)
# we check the first parameter for the frame function is
# named 'self'
if len(args) and args[0] == 'self':
# in that case, 'self' will be referenced in value_dict
instance = value_dict.get('self', None)
if instance:
# return its class
return getattr(instance, '__class__', None)
# return None otherwise
return None
如果不想使用^{},可以直接使用frame.f_locals,而不是value_dict,也可以直接使用frame.f_code.co_varnames[:frame.f_code.co_argcount],而不是args。
请记住,这仍然只依赖于约定,因此它不可移植,而且容易出错:如果非方法函数使用self作为第一个参数名,那么get_class_from_frame将错误地返回第一个参数的类。
使用描述符时可能会产生误导(它将返回描述符的类,而不是被访问的实际实例的类)。
@classmethod和@staticmethod不接受self参数,并使用描述符实现。
当然还有很多
取决于您到底想做什么,您可能需要花一些时间深入挖掘并找到解决所有这些问题的方法(您可以检查返回类中存在的框架函数并共享同一源,检测描述符调用是可能的,类方法也是如此等等)