Pylance не перехватывает все устаревшие функции и классы

Недавно я обновил версию Python нашего приложения с 3.8 до 3.12, что потребовало обновления нескольких библиотек, несовместимых с новой версией Python. С тех пор я столкнулся с проблемами, когда некоторые функции и классы устарели.

Я использую Pylance в коде Visual Studio, и хотя он улавливает некоторые устаревшие объекты, такие как:

ему не удается перехватить другие устаревшие классы, которые я обнаруживаю только во время выполнения, например flask.json.JSONEncoder:

Оба устаревания указаны в их реализациях:

Datetime.datetime.utcnow:

@classmethod
def utcnow(cls):
    "Construct a UTC datetime from time.time()."
    import warnings
    warnings.warn("datetime.datetime.utcnow() is deprecated and scheduled for "
                  "removal in a future version. Use timezone-aware "
                  "objects to represent datetimes in UTC: "
                  "datetime.datetime.now(datetime.UTC).",
                  DeprecationWarning,
                  stacklevel=2)
    t = _time.time()
    return cls._fromtimestamp(t, True, None)

flask.json.JSONEncoder:

    def __init__(self, **kwargs) -> None:
        import warnings

        warnings.warn(
            "'JSONEncoder' is deprecated and will be removed in"
            " Flask 2.3. Use 'Flask.json' to provide an alternate"
            " JSON implementation instead.",
            DeprecationWarning,
            stacklevel=3,
        )
        super().__init__(**kwargs)


Почему Pylance улавливает некоторые устаревшие объекты, но не другие, оставляя некоторые из них обнаруживаемыми только во время выполнения?

И есть ли какие-нибудь инструменты, которые могут статически улавливать эти устаревания?

Предположительно, Pylance жестко запрограммировал известные устаревшие версии стандартной библиотеки, вообще не пытаясь обнаружить устаревшие версии в исходном коде. Это может измениться в Python 3.13, когда декоратор deprecated станет официальным.

chepner 17.06.2024 20:10
Почему в Python есть оператор "pass"?
Почему в Python есть оператор "pass"?
Оператор pass в Python - это простая концепция, которую могут быстро освоить даже новички без опыта программирования.
Некоторые методы, о которых вы не знали, что они существуют в Python
Некоторые методы, о которых вы не знали, что они существуют в Python
Python - самый известный и самый простой в изучении язык в наши дни. Имея широкий спектр применения в области машинного обучения, Data Science,...
Основы Python Часть I
Основы Python Часть I
Вы когда-нибудь задумывались, почему в программах на Python вы видите приведенный ниже код?
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
Алиса и Боб имеют неориентированный граф из n узлов и трех типов ребер:
Оптимизация кода с помощью тернарного оператора Python
Оптимизация кода с помощью тернарного оператора Python
И последнее, что мы хотели бы показать вам, прежде чем двигаться дальше, это
Советы по эффективной веб-разработке с помощью Python
Советы по эффективной веб-разработке с помощью Python
Как веб-разработчик, Python может стать мощным инструментом для создания эффективных и масштабируемых веб-приложений.
0
1
60
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Pyright/Pylance пойман utcnow(), потому что он был явно помечен как устаревший в typeshed, который является источником статической типизации стандартной библиотеки:

class timezone(tzinfo):
    ...
    @deprecated("Use timezone-aware objects to represent datetimes in UTC; e.g. by calling .now(datetime.UTC)")
    def utcnow(cls) -> Self: ...

С другой стороны, flask.json.JSONEncoderне было.

@deprecated, который будет представлен в Python 3.13 warnings через PEP 702 , уже можно импортировать из typing_extensions. Обе реализации совершенно одинаковы и, следовательно, имеют одинаковые эффекты при повышении DeprecationWarning во время выполнения.

datetime.utcnow объявлен в _pydatetime.py, а не в typeshed, и там он не помечен как устаревший. github.com/python/cpython/blob/…

LDevelop 17.06.2024 20:59

@LDevelop Как уже говорилось, Pyright/Pylance получает статическую информацию о типизации из typeshed, а не из фактического кода. См. README для более подробного объяснения. Символы Stdlib обычно не имеют прямых указаний типа.

InSync 17.06.2024 21:00

Теперь это имеет смысл, спасибо!

LDevelop 17.06.2024 21:07

Другие вопросы по теме