Отдельно разберём 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
#TIIF2025#Agenda#11th_June
Panel session: Investor Protection: The New Investment Law, International Arbitration, and Domestic Court System
Venue: Room Kokand
Time: 16:00-17:00
Join Live broadcasting: YouTube
#TIIF2025#Agenda#11th_June
Panel session: Karakalpakstan’s Economic Development Strategy: Present Realities, Growth Dimensions, and Future Opportunities
Venue: Room Bukhara
Time: 16:00-17:00
Join Live broadcasting: YouTube Uz
Join Live broadcasting: YouTube En
#TIIF2025#Agenda#11th_June
Panel session: Privatization: Plans, Approaches, and Achievements
Venue: Room Khiva
Time: 14:00-15:00
Join Live broadcasting: YouTube Uz
Join Live broadcasting: YouTube En
#TIIF2025#Agenda#11th_June
Panel session: Uzbekistan as a Strategic Hub for Critical Raw Materials: Investment Opportunities Across the Value Chain
Venue: Room Kokand
Time: 14:00-15:00
Join Live broadcasting: YouTube
#TIIF2025#Agenda#11th_June
Panel session: Global Trade Fragmentation and Neo-Protectionism: Lessons from the Past, Current Challenges and Implications for Central Asia’s Regional and Global Value Chain Integration Efforts
Venue: Room Samarkand
Time: 14:00-15:00
Join Live broadcasting: YouTube
#TIIF2025#Agenda#11th_June
Panel session: Journey of TBC as a Market Disruptor Shaping Online Banking in Uzbekistan
Venue: Room Kokand
Time: 12:00-13:00
Join Live broadcasting: YouTube
#TIIF2025#Agenda#11th_June
Panel session: Ceasing Water Resources: Solutions, Strategies, and State Priorities
Venue: Room Khiva
Time: 12:00-13:00
Join Live broadcasting: YouTube Uz
Join Live broadcasting: YouTube En
#TIIF2025#Agenda#11th_June
Panel session: IT Sector and AI: Empowering Youth to Drive Innovation and Develop World-Class Solutions
Venue: Room Bukhara
Time: 12:00-13:00
Join Live broadcasting: YouTube Uz
Join Live broadcasting: YouTube En
#TIIF2025#Agenda#11th_June
Panel session: Global Brands as Catalysts: Enhancing National Investment Appeal through Luxury and Innovation
Venue: Room Samarkand
Time: 11:00-12:00
Join Live broadcasting: YouTube