Skip to main content

Async generators and context managers for Python 3.5+

Project description

Join chatroom Documentation Status Automated test status Automated test status (Windows) Test coverage

The async_generator library

Python 3.6 added async generators. (What’s an async generator? Check out my 5-minute lightning talk demo from PyCon 2016.) Python 3.7 adds some more tools to make them usable, like contextlib.asynccontextmanager.

This library gives you all that back to Python 3.5.

For example, this code only works in Python 3.6+:

async def load_json_lines(stream_reader):
    async for line in stream_reader:
        yield json.loads(line)

But this code does the same thing, and works on Python 3.5+:

from async_generator import async_generator, yield_

@async_generator
async def load_json_lines(stream_reader):
    async for line in stream_reader:
        await yield_(json.loads(line))

Or in Python 3.7, you can write:

from contextlib import asynccontextmanager

@asynccontextmanager
async def background_server():
    async with trio.open_nursery() as nursery:
        value = await nursery.start(my_server)
        try:
            yield value
        finally:
            # Kill the server when the scope exits
            nursery.cancel_scope.cancel()

This is the same, but back to 3.5:

from async_generator import async_generator, yield_, asynccontextmanager

@asynccontextmanager
@async_generator
async def background_server():
    async with trio.open_nursery() as nursery:
        value = await nursery.start(my_server)
        try:
            await yield_(value)
        finally:
            # Kill the server when the scope exits
            nursery.cancel_scope.cancel()

(And if you’re on 3.6, you can use @asynccontextmanager with native generators.)

Let’s do this

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

async_generator-1.9.tar.gz (15.7 kB view details)

Uploaded Source

Built Distribution

async_generator-1.9-py3-none-any.whl (18.6 kB view details)

Uploaded Python 3

File details

Details for the file async_generator-1.9.tar.gz.

File metadata

File hashes

Hashes for async_generator-1.9.tar.gz
Algorithm Hash digest
SHA256 b7d5465c6174fe86dba498ececb175f93a6097ffb7cc91946405e1f05b848371
MD5 a0a4922839f6309135e4122975ed4a96
BLAKE2b-256 d6fdd9c76bac900882ceb0b2579d071588f60556557cc5d1a92ddcade14cc210

See more details on using hashes here.

File details

Details for the file async_generator-1.9-py3-none-any.whl.

File metadata

File hashes

Hashes for async_generator-1.9-py3-none-any.whl
Algorithm Hash digest
SHA256 2f45541002a14f80fffc6d52788f92470ff0d9bfe81c434ea8cd60babe43de9e
MD5 8fb128e275f61d4e2fa3e7dc4bb0221c
BLAKE2b-256 d9c94a1806709a86b0e81849abb51242a4c6cfaba9c52dce05828e9125d7081d

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page