Я пытаюсь добавить подсказки типов к статическому методу в Python, используя typing.Self. Однако подсказка типа не применяется к аргументу self внутри самой функции.
from typing import Self
class Vect:
x: float
y: float
@staticmethod
def angle(v1: Self, v2: Self):
return math.acos(v1 * v2 / v1.magnitude() / v2.magnitude())
Код работает, но он не дает мне никаких подсказок по типу метода angular для переменных v1 и v2.
Если вам по какой-либо причине нужен такой API, используйте @classmethod, а не @staticmethod.






Вы не можете использовать Self в статическом методе. По определению статический метод не принимает self в качестве параметра.
Итак, сделайте это нормальным методом
import math
from typing import Self
class Vect:
x: float
y: float
def angle(self, v1: Self, v2: Self):
return math.acos(v1 * v2 / v1.magnitude() / v2.magnitude())
Для этого метода не имеет особого смысла требовать 3 экземпляра объекта, но первоначальное объяснение правильное — ввод Self недопустим для @staticmethods, поскольку они по своей сути не привязаны к классу, в котором находятся.
typing.Self предназначен для использования, например, в методах, возвращающих self, или в методах класса, которые являются альтернативными конструкторами, но статические методы не имеют параметра self или cls.
Одним из способов ввода подсказки для статического метода является использование прямых ссылок, что позволяет указывать имена типов, которые еще не определены.
from typing import Self
class Vect:
x: float
y: float
@staticmethod
def angle(v1: 'Vect', v2: 'Vect'):
return math.acos(v1 * v2 / v1.magnitude() / v2.magnitude())
Стоит упомянуть одну из альтернатив: использование from __future__ import annotations и ввод самого класса — angle(v1: Vect, v2: Vect)
В этом случае
@staticmethod— не лучший выбор. Возможно, это должен быть обычный метод, который можно набрать просто какdef angle(self, other: Self) -> float.