Я пытаюсь реализовать функцию infer_class
, которая, учитывая метод, вычисляет класс, к которому принадлежит метод.Как определить класс, которому принадлежит @staticmethod?
До сих пор у меня есть что-то вроде этого:
import inspect
def infer_class(f):
if inspect.ismethod(f):
return f.im_self if f.im_class == type else f.im_class
# elif ... what about staticmethod-s?
else:
raise TypeError("Can't infer the class of %r" % f)
Это не работает для @ STATICMETHOD-s, потому что я не был в состоянии придумать способ для достижения этой цели.
Любые предложения?
Вот в действии infer_class
:
>>> class Wolf(object):
... @classmethod
... def huff(cls, a, b, c):
... pass
... def snarl(self):
... pass
... @staticmethod
... def puff(k,l, m):
... pass
...
>>> print infer_class(Wolf.huff)
<class '__main__.Wolf'>
>>> print infer_class(Wolf().huff)
<class '__main__.Wolf'>
>>> print infer_class(Wolf.snarl)
<class '__main__.Wolf'>
>>> print infer_class(Wolf().snarl)
<class '__main__.Wolf'>
>>> print infer_class(Wolf.puff)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "<stdin>", line 6, in infer_class
TypeError: Can't infer the class of <function puff at ...>
У вас есть источник, вы можете прочитать родительский класс. Зачем тебе это нужно? Что вы пытаетесь достичь? –
Предположим, я хотел написать функцию, которая временно заглушает функцию или метод (перехватывать вызовы или что-то еще для целей тестирования). Чтобы это сделать, мне нужны два компонента: объект, содержащий функцию, и имя функции, чтобы я мог делать 'setattr (obj, func_name, my_stub)'. Если f является модульной функцией, я использую 'inspect.getmodule (f)' для получения объекта и 'f .__ name__' для получения своего имени. Для методов класса и методов экземпляра я использую приведенный выше код. Казалось бы, для статических методов мне повезло. –