Как получить доступ к атрибуту __class__ метода вызывающего из функции вызываемого в Python? - PullRequest
1 голос
/ 02 июня 2019

Здесь __class__ не следует путать с self.__class__, к которому я уже могу получить доступ с помощью модуля inspect:

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

1 Ответ

3 голосов
/ 02 июня 2019

Неявная ссылка __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 заклинаний:

  1. Найти вызывающую функцию: Как получить текущую функцию в переменную?
  2. Найдите класс этой функции: Получите определяющий класс несвязанного объекта метода в Python 3

Я бы не советовал.

...