loop = asyncio.get_event_loop()
executor = concurrent.futures.ThreadPoolExecutor(max_workers=5)
tasks = [loop.run_in_executor(executor, self.parse_url, url) for url in urls]
await asyncio.wait(tasks, timeout=5)
for (i, task) in zip(urls, tasks):
result = task.result() if task._state.lower() == 'finished' else []
В приведенном выше коде я использую свойство _state, чтобы проверить, действительно ли задание завершено и не истекло время ожидания.
Есть ли более чистый способ сделать это?Я не думаю, что должен получить доступ к свойству _state, как это.