Отдельно разберём 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
nueva página en mi #obsidian esta vez con temática dark academia 🕰🕯 PD: la chica que sale "estudiando" es del webtoon jacinto purpura
-> descargar las img que use <-
después de horas de trabajo les presento mi homepage en #obsidian
くコ:彡
debido a mis problemas de salud y tal me ha costado adaptarme a la normalidad. Igual ya me estoy planeando para el próximo mes.
Estoy comenzando a trabajar en una página de #obsidian para los libros que voy leyendo. Incluye resúmenes de sus capítulos, personajes y palabras que no conozca su significado. ¿ Ustedes realizan lectura activa ? Es decir, subrayan frases que les gustan del libro que leen , buscan palabras raras , hablan del libro a un amigo y debaten . Yo antes no lo hacía, pero el año pasado ví un video que me motivo mucho a crearme el habito de leer todos los días.
video súper recomendado abajito 🤓👇