Python 3.6 异步函数以最简单的方式循环

Posted

技术标签:

【中文标题】Python 3.6 异步函数以最简单的方式循环【英文标题】:Python 3.6 async function over loop in the simplest way possible 【发布时间】:2019-09-10 19:11:01 【问题描述】:

我需要做的就是编写一个简单的异步函数来返回一些东西。类似于

async def diss(lis):
  x = []
  for i in lis:
    x.append(i + 1) #the operation is arbitrary, but the input and output of a list is the desired result
  return x

lis = [1, 2, 3, 4]
res = await diss(lis)

但是,这给了我在 await diss(lis) 处的语法错误

我在网上找到的都是一些教程,其中在异步函数中打印了一些东西,但是当我尝试返回一些东西时,我总是收到一个协程或未来对象。

我的目标本质上是让循环异步运行,以提高性能,然后返回一些东西

【问题讨论】:

您是否尝试在事件循环之外等待协程?您需要获取或创建一个事件循环并在其中运行协程。最简单的方法是使用asyncio.run 根据[***.com/questions/52796630/…我发现python 3.6 asyncio不支持运行 【参考方案1】:

给你:

import asyncio


async def diss(lis):
  x = []
  for i in lis:
    x.append(i + 1)
  return x


async def main():
  lis = [1, 2, 3, 4]
  res = await diss(lis)
  return res


loop = asyncio.get_event_loop()
res = loop.run_until_complete(main())
print(res)

确保您了解why and when to use asyncio in the first place。例如,没有必要使上面的代码异步。

通常,当您有多个可以与 asyncio.gather() 并行化的 I/O 操作时,您可能只需要 asyncio

【讨论】:

谢谢。我想我对异步操作太陌生了,不知道。这非常有帮助。我需要执行的实际操作涉及调用在服务器上进行计算的外部 api。我想我需要使用进程池执行程序来做我需要做的事情。我只需要想出一种方法来循环将每个操作放在自己的进程中。再次感谢您 这是否意味着我们应该使这段代码同步而不是异步? @mic 在这种情况下:是的。没有法律规定这段代码应该是同步的,但让它异步是没有意义的。你只是不会从中得到任何好处。通常,只有在处理某些 I/O 或作为并行化某些计算的一种方式(当您可以并行化它们时)时,您才想编写异步代码。请从链接中查看the answer,那里的示例很少。【参考方案2】:
async def diss(lis):
  x = []
  for i in lis:
    x.append(i + 1)
  return x

async def dat():
  res = await diss(lis)
  return res

loop = asyncio.get_event_loop()

done, _ = loop.run_until_complete(asyncio.wait([dat()]))

for fut in done:
    a = fut.result()

是我为解决 a 是预期结果的问题所做的。这有什么问题吗?

【讨论】:

它可以写得更短:result = loop.run_until_complete(dat())。当并行等待几件事情时,你只需要 asyncio.wait()。

以上是关于Python 3.6 异步函数以最简单的方式循环的主要内容,如果未能解决你的问题,请参考以下文章

自己手写调度器,理解Python中的asyncio异步事件循环与协程

自己手写调度器,理解Python中的asyncio异步事件循环与协程

自己手写调度器,理解Python中的asyncio异步事件循环与协程

如何在python中循环列表? [复制]

以最简单的方式在 Matplotlib 中的 PyPlot 中添加图例

如何在swift中以最简单的方式画一条线