Отдельно разберём TaskGroup, который пришел на замену gather в Python 3.11.
Ключевые отличия
▫️create_task() возвращает объект asyncio.Task, у которого есть соответствюущие методы управления. То есть у нас больше контроля
▫️это контекстный менеджер, который гарантирует что все таски будут остановлены по выходу из контекста
▫️ошибка автоматически отменяет незавершенные задачи,
▫️except* передает нам ExceptionGroup, в котором каждую ошибку можно обработать отдельно
import asyncio
import random
async def do_it() -> str:
if random.random() < 0.1:
raise ValueError('Oops')
delay = random.uniform(0.5, 1.5)
await asyncio.sleep(delay)
return delay
async def main():
try:
async with asyncio.TaskGroup() as tg:
for _ in range(10):
tasks.append(tg.create_task(do_it()))
for t in tasks:
print(t.result())
except *ValueError as e:
for err in e.exceptions:
print(err)
asyncio.run(main())
Рекомендую изучить страницу Coroutines and Tasks из документации, где представлено больше интересных примеров и механизмов
- таймауты
- отмена задач
- создание задач из другого потока
#async
#week
Доброго утра друзья.
Начинается важная неделя по макро-показателям.
Видео обзор запушу позже если успею 😎
а пока тезисно по моим ожиданиям:
✅показатели по инфляции в США укажут на замедление инфляции.
✅Потреб настроение улучшится, в следствии падения цен на бензин и отскока в ряде голубых фишек.
✅Рост ВВП Китая будет выше рыночного ожидания в 1%
В следствии выше перечисленных ожиданий покую:
✅SP500 с текущих уровней 3766-75 оставляю маневр добавки по 3755. Первые цели роста 4050/60
В случае снижения ниже 3735 буду пересматривать цели и уменьшать объемы покупок.
✅Покупаю Salana уровни 35/36, далее добавлять буду 37,38,39,40 цели 44 первая.
В случае снижения ниже 33,5 буду снижать объемы покупок.
не является инвестиционной рекомендацией.