如何异步映射/过滤异步可迭代对象?
假设我有一个异步可迭代对象,可以使用来传递它async
for
,然后又如何将其映射并过滤到新的异步迭代器上?以下代码是对我如何使用同步可迭代方法执行相同操作的适应,因此不起作用,因为syield
内部不允许这样做async
def
。
async def mapfilter(aiterable, p, func):
async for payload in aiterable:
if p(payload):
# This part isn't allowed, but hopefully it should be clear
# what I'm trying to accomplish.
yield func(payload)
-
一个最近公布的PEP草案(PEP 525)
,其支持定为Python
3.6,建议允许异步发电机与你想出了相同的语法。同时,如果您不想处理异步迭代器样板,还可以使用CryingCyclops在其注释中
asyncio_extras
提到的库。从文档:
@async_generator async def mygenerator(websites): for website in websites: page = await http_fetch(website) await yield_async(page) async def fetch_pages(): websites = ('http://foo.bar', 'http://example.org') async for sanitized_page in mygenerator(websites): print(sanitized_page)
还有一个支持构造的async_generator库
yield from
。