Implementing an asynchronous iterator

前端 未结 2 1827
一个人的身影
一个人的身影 2021-01-06 19:35

Per PEP-492 I am trying to implement an asynchronous iterator, such that I can do e.g.

async for foo in bar:
    ...

Here is a trivial exa

相关标签:
2条回答
  • 2021-01-06 19:53

    If you read a little further down the documentation it mentions that (emphasis mine):

    PEP 492 was accepted in CPython 3.5.0 with __aiter__ defined as a method, that was expected to return an awaitable resolving to an asynchronous iterator.

    In 3.5.2 (as PEP 492 was accepted on a provisional basis) the __aiter__ protocol was updated to return asynchronous iterators directly.

    Therefore for versions prior to 3.5.2 (released 2016/6/27) the documentation is slightly out of step with how to write a working asynchronous iterator. The fixed version for 3.5.0 and 3.5.1 looks like:

    class TestImplementation:
        async def __aiter__(self):
      # ^ note
            return self
        async def __anext__(self):
            raise StopAsyncIteration
    

    This was introduced on closing bug #27243 and is a little clearer in the data model documentation, which also suggests a way of writing backwards compatible code.

    0 讨论(0)
  • 2021-01-06 20:01

    Asynchronous iterators have been implemented in Python 3.6 - see PEP-525

    Then you don't need your TestImplementation at all in order to use async for. You can just use yield (example taken from PEP-525):

    async def ticker(delay, to):
        """Yield numbers from 0 to `to` every `delay` seconds."""
        for i in range(to):
            yield i
            await asyncio.sleep(delay)
    

    You can then use async for as you would expect:

    async for i in ticker(1, 10):                                                                     
        print(f'Tick #{i}')
    
    0 讨论(0)
提交回复
热议问题