TGTGInsighttelegram intelligenceLIVE / telegram public index
← Python Заметки

TGINSIGHT SIMILAR POSTS

Најди сличен содржај

Изворен канал @pythonotes · Post #64 · 6 апр.

Думаете ˍˍfutureˍˍ нужен только для Python2? Нет, это процесс постоянный. В Python3 тоже есть свои "future". from __future__ import annotations Похоже на бекпорт аннотаций типов из Python3 в Python2, но это не так. Это имплементация PEP 563 Postponed Evaluation of Annotations которая будет дефолтной только в Python4. Что делает этот future? Если вы активно используете аннотации типов в Python3 то знаете, как они обычно выглядят. def func(x: int) -> int: return x * 2 При этом у объекта функции появляется атрибут ˍˍannotationsˍˍ >>> print(func.__annotations__) {'x': <class 'int'>, 'return': <class 'int'>} Видно, что в этой переменной находится словарь. Ключ словаря это имя аргумента функции, а значение это непосредственно ссылка на тип. А так же есть тип для return. В более сложных случаях это будут инстансы объектов из модуля typing from typing import List def func(x: int) -> List[int]: return [x] * 10 >>> print(func.__annotations__) {'x': <class 'int'>, 'return': typing.List[int]} Что происходит если мы импортим annotations из ˍˍfutureˍˍ? Изменяется способ определения аннотаций. Дело в том, что все эти инстансы типов создаются в момент определения функции когда модуль импортируется. Так же как и значения по умолчанию они должны исполниться и вернуть какой-то объект. В нашем случае это ссылка на тип int или инстанс класса typing.List. И тут возникает две проблемы, описаные в PEP. Если коротко то звучит это так: 1. Если в подсказке указывается тип, который еще не определён, это вызовет ошибку. Приходится описывать его просто строкой или менять порядок определения. 2. Определение ссылок на типы порой занимает много времени, так как требуется импорт модулей и создание инстансов. Но если вы импортируете наш future, то активируется так называемое отложенное определение ссылок (Postponed Evaluation of Annotations). В результате вместо создания инстансов и ссылок в ˍˍannotationsˍˍ просто записывается строка с этой подсказкой. from __future__ import annotations def func(x: int) -> int: return x * 2 >>> print(func.__annotations__) {'x': 'int', 'return': 'int'} В дальнейшем ваши IDE и ресолверы типов могут брать эти строки и исполнять самостоятельно где то на фоне, когда все необходимые типы уже определены. Для преобразования этих строк в привычный вид есть готовая функция >>> import typing >>> typing.get_type_hints(func) {'x': <class 'int'>, 'return': <class 'int'>} Но делать это можно уже только по необходимости. #pep

Hashtags

Резултати

Пронајдени 124 слични објави

Пребарај: #aria

当前筛选 #aria清除筛选
CryptoBull_360™

@cryptobull_360 · Post #48708 · 10.03.2026 г., 09:02

✨ ✨#ARIA Trade in VIP channel👀📈📈 👍👍Congratulations VIP Members 💸💸 What are you waiting for? You are missing huge profits 💰😎 ‼️ Recover fee within few hours ‼️ ☑️ Join VIP @CryptoBull_360_admin☑️

Hashtags

Crypto Signals & Bot Trades

@cryptosignalalert · Post #27815 · 05.12.2025 г., 17:37

💰💰#ARIA/USDT delivered huge profits for our premium members — proof of why we're among the best in the game! 👁‍🗨 Want to trade smarter and faster? Contact @cripexperts to join our premium group and trade with top-tier experts.

Hashtags

Free Crypto Signals (Profitable Zone)

@btctradingclub · Post #26524 · 05.12.2025 г., 13:25

✅✅88% Profit on #ARIA/USDT for our Premium Members on Binance Futures/Bybit/OKEX - All profit targets completed 👁‍🗨Contact @primemod to enter the Premium Group and trade on high quality SPOT as well as FUTURES Calls

Hashtags

123•••1011
ПретходнаСтраница 1 од 11Следна