Отдельно разберём 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
Choc Chip Banana Bread ✨🍌🤎
Ingredients:
* 3 large ripe bananas (360–380 g)
* 130 g unsalted butter (will reduce to \~115 g once browned)
* 180 g dark brown sugar (+ 1–2 tbsp for topping)
* 2 large eggs
* 250 g plain flour
* 1 tsp baking soda
* ½ tsp salt
* ½ tsp cinnamon
* 70–100 g dark chocolate, chopped
* Optional: chopped nuts
#dinner
@dishes
My Kind of Girl Dinner 😮💨🍚🥒
Ingredients:
For the salmon:
* 2 salmon fillets (skin removed, cut into cubes)
* 2 tbsp soy sauce
* 1 tbsp oyster sauce
* 1 tsp brown sugar
* 2 tsp minced garlic
* 1 tbsp sriracha
* ¼ tsp chili flakes
For the rice & toppings:
* 100 g sushi rice (cooked)
* 1 tsp apple cider vinegar
* ½ tsp salt
* ½ tsp sugar
* Pinch of chili flakes
* ¼ cucumber, thinly sliced
* ¼ small onion, thinly sliced
* Handful of edamame (cooked)
* Black & white sesame seeds, for topping
#dinner
@dishes