繁体   English   中英

Python asyncio - 如何创建任务列表并在事件循环中使用它?

[英]Python asyncio - How to create task list and use it in the event loop?

我在 Python asyncio 方面不是很有经验,尽管同步 Python 进展顺利。 我有一个函数,它创建一个任务列表,另一个函数将被这个列表中的任务调用:

import asyncio

async def createTasks(some_dict):
    coroutines = []
    # some_dict can have an arbitrary number of items
    for item in some_dict:
        coroutines.append(executeOneTask(item))
    tasks = await asyncio.gather(*coroutines, return_exceptions=True)
    return tasks

async def executeOneTask(item):
    # execute a task asynchronously
    return

如果我错了,这是您可以自由纠正我的部分。

现在,我对 asyncio 的理解是我需要一个事件循环来执行异步函数,这意味着对于asyncio.gather我需要await它,这意味着这需要在async函数中发生。 好的,所以我需要一个事件循环来创建我实际上想要异步执行的异步任务列表。

如果我对事件循环的理解是正确的,我就不能轻易地将事件循环内的任务添加到同一个事件循环中。 假设我有一个异步main()函数,它应该首先使用createTasks()检索异步任务列表,然后使用executeOneTask()创建要运行的异步任务数量(等于列表长度executeOneTask()

我应该如何构建这样的main()函数? 我需要多个事件循环吗? 我可以通过其他方式创建任务列表,从而使代码更简单吗?

旁注:我在这里设置的方法可能是解决问题的一种非常困难或颠倒的方法。 我的目标是创建一个异步任务列表,然后异步运行这些任务。 如果智能解决方案需要,请随意不遵循上面的代码结构。

谢谢!

您应该在整个应用程序中只使用一个事件循环。 通过asyncio.run(main())启动 main 函数, asyncio.run(main())为您创建一个循环。 在 Python 3.8 中,您很少需要直接访问或使用循环,但在旧版本中,如果使用循环方法或某些需要循环参数的函数,您可以通过asyncio.get_event_loop()获得它。

请注意,IPython(在 Spyder 和 Jupyter 中使用)也运行自己的循环,因此在那些循环中,您可以直接调用和await而无需调用asyncio.run

如果您只想进行异步编程但并不特别需要使用 asyncio,我建议您查看https://trio.readthedocs.io/ ,它基本上可以做同样的事情,但使用起来要容易得多(正确)。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM