Индикатор выполнения asyncio aiohttp с tqdm
Я пытаюсь интегрировать tqdm
индикатор выполнения для мониторинга запросов POST, сгенерированных с aiohttp
в Python 3.5. У меня есть рабочий индикатор, но я не могу собрать результаты, используя as_completed()
, Указатели с благодарностью получены.
Примеры, которые я нашел, предлагают использовать следующий шаблон, который несовместим с Python 3.5 async def
определения:
for f in tqdm.tqdm(asyncio.as_completed(tasks), total=len(coros)):
yield from f
Рабочий (хотя и отредактированный по частям) асинхронный код без индикатора выполнения:
def async_classify(records):
async def fetch(session, name, sequence):
url = 'https://app.example.com/api/v0/search'
payload = {'sequence': str(sequence)}
async with session.post(url, data=payload) as response:
return name, await response.json()
async def loop():
auth = aiohttp.BasicAuth(api_key)
conn = aiohttp.TCPConnector(limit=100)
with aiohttp.ClientSession(auth=auth, connector=conn) as session:
tasks = [fetch(session, record.id, record.seq) for record in records]
responses = await asyncio.gather(*tasks)
return OrderedDict(responses)
Это моя неудачная попытка модификации loop()
:
async def loop():
auth = aiohttp.BasicAuth(api_key)
conn = aiohttp.TCPConnector(limit=100)
with aiohttp.ClientSession(auth=auth, connector=conn) as session:
tasks = [fetch(session, record.id, record.seq) for record in records]
for f in tqdm.tqdm(asyncio.as_completed(tasks), total=len(tasks)):
await f
responses = await asyncio.gather(f)
print(responses)
1 ответ
Решение
await f
возвращает один ответ. Зачем сдавать уже законченный Future
в asyncio.gather(f)
неясно.
Пытаться:
responses = []
for f in tqdm.tqdm(asyncio.as_completed(tasks), total=len(tasks)):
responses.append(await f)
Python 3.6 реализует PEP 530 - Асинхронное понимание:
responses = [await f
for f in tqdm.tqdm(asyncio.as_completed(tasks), total=len(tasks))]
Это работает внутри async def
функционирует сейчас.