Async generators and context managers for Python 3.5+
Project description
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
Install: python3 -m pip install -U async_generator (or on Windows, maybe py -3 -m pip install -U async_generator
Bug tracker and source code: https://github.com/python-trio/async_generator
Real-time chat: https://gitter.im/python-trio/general
License: MIT or Apache 2, your choice
Contributor guide: https://trio.readthedocs.io/en/latest/contributing.html
Code of conduct: Contributors are requested to follow our code of conduct in all project spaces.
How come some of those links talk about “trio”?
Trio is a new async concurrency library for Python that’s obsessed with usability and correctness – we want to make it easy to get things right. The async_generator library is maintained by the Trio project as part of that mission, and because Trio uses async_generator internally.
You can use async_generator with any async library. It works great with asyncio, or Twisted, or whatever you like. (But we think Trio is pretty sweet.)
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
Built Distribution
File details
Details for the file async_generator-1.9.tar.gz
.
File metadata
- Download URL: async_generator-1.9.tar.gz
- Upload date:
- Size: 15.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b7d5465c6174fe86dba498ececb175f93a6097ffb7cc91946405e1f05b848371 |
|
MD5 | a0a4922839f6309135e4122975ed4a96 |
|
BLAKE2b-256 | d6fdd9c76bac900882ceb0b2579d071588f60556557cc5d1a92ddcade14cc210 |
File details
Details for the file async_generator-1.9-py3-none-any.whl
.
File metadata
- Download URL: async_generator-1.9-py3-none-any.whl
- Upload date:
- Size: 18.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2f45541002a14f80fffc6d52788f92470ff0d9bfe81c434ea8cd60babe43de9e |
|
MD5 | 8fb128e275f61d4e2fa3e7dc4bb0221c |
|
BLAKE2b-256 | d9c94a1806709a86b0e81849abb51242a4c6cfaba9c52dce05828e9125d7081d |