Отдельно разберём 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
#SKL/USDT analysis :
#SKL is currently facing rejection at the resistance zone. The price is expected to decline from this point and continue to decrease, testing the support levels. Previous lows are likely to be tested. Wait for pullback for short entry.
TF : 4h
Entry : $0.04237
Target : $0.03509
SL : $0.04648
#SKL/USDT analysis :
#SKL has been rejected from the high time frame (HTF) resistance zone and has broken the support level. This indicates that the price is likely to continue declining further and test the previous swing low.
TF : 15min
Entry : $0.03413
Target : $0.03211
SL : $0.03541