Функция asyncio.wait() это еще один способ вызвать множество асинхронных задач.
Она работает в нескольких режимах.
1. Самый простой - ждем завершения всех задач
async def main():
tasks = [asyncio.create_task(do_it(i)) for i in range(10)]
done, pending = await asyncio.wait(
tasks,
return_when=asyncio.ALL_COMPLETED
)
for task in done:
try:
print(task.result())
except Exception as e:
print(e)
Очень похоже на gather, но работает не так.
▫️возвращает не результаты, а два сета с объектами Task у которых можно забрать результат через task.result() если они в списке done
▫️не гарантирует порядок результатов так как оба объекта это set
▫️не выбрасывает исключение когда оно появляется, а сохраняет его в Task. Исключение появится когда попробуете забрать резултьтат.
2. Ждем завершения первой задачи, даже если там ошибка.
async def main():
tasks = [asyncio.create_task(do_it(i)) for i in range(3)]
done, pending = await asyncio.wait(
tasks,
return_when=asyncio.FIRST_COMPLETED
)
# в done может быть несколько задач!
for task in done:
try:
print(task.result())
except Exception as e:
print(f"Fail: {e}")
# Оставшиеся задачи в pending, как правило, нужно отменить, иначе они будут продолжать работать
for task in pending:
task.cancel()
В сете done будут таски которые успели завершится, причем как успешно так и нет.
3. До первой ошибки.
Тоже самое, но с аргументом FIRST_EXCEPTION
done, pending = await asyncio.wait(
tasks,
return_when=asyncio.FIRST_EXCEPTION
)
Функция завершается как только первая задача упадет с ошибкой.
Учтите, что в любом случае done вы можете обранужить несколько задач, как с ошибками так и успешные.
↗️ Полный листинг примеров здесь
#async
Наблюдаю за трендом во всех “lifestyle”-нишах за 24 год и в Q1 ’25. Видно что повторяется один и тот же паттерн. Например в категории ухода за зубами хештег #TeethWhitening прибавил 40 %, тогда как #Teethcare — 90 %. То же самое и в других нишах: бьюти-маски (#SheetMask +35 % vs #SkinCareRoutine +120 %), уход за волосами (#HairMask +45 % vs #HairCareRoutine +90 😵 и кулинария (#EasyRecipe +40 % vs #MealPrepSunday +95 %).
Все это происходит потому что алгоритмы соцсетей награждают контент с продолжительным временем просмотра и возвратами аудитории, когда пользователи начинают искать лайфхаки или чёткие схемы, позволяющие выработать привычку и контролировать прогресс, плюс, формат «рутина» укрепляет доверие: многократные касания к теме создают эффект экспертности и укрепляют связь с подписчиками.
В результате бренды и блогеры переходят от «до/после» к пошаговым инструкциям. Это касается утренних и вечерних бьюти-рутнин, сплит-тренировок по дням недели и планирования питания на неделю. Серии роликов «шаг за шагом» не только удерживают внимание, но и формируют вокруг контента активное сообщество, где подписчики делятся опытом и возвращаются за новыми выпусками.
Мне сразу стало интересно можно ли перенести такой подход от lifestyle к продаже например люксовых товаров, может сумок или ювелирки, где сам по себе чек уже довольно высокий и не существует как таковой рутины способной улучшить результат в будущем. Если появятся какие то мысли буду рад если напишите в комментах.
@mosunovc
High Protein Red Cabbage Rolls
Ingredients:
🥬 1 large red cabbage
🫚 4 cm ginger
🧄 3 cloves of garlic
🥕 2 carrots
🫑 2 peppers
🧅 2 spring onions
🌱 100 g soy granules
🍶 50 ml soy sauce
Toppings:
✨ Sesame, 🌿 fresh parsley, 🌶 chili flakes
Dip:
🍯 Sweet Chili Sauce
#HighProtein#RedCabbageRolls#HealthyEating#PlantBased#EasyRecipe#SoyGranules#VeggiePower#Flavorful#MealPrep
@dishes