A Requests session that returns awaitable Twisted Deferreds instead of response objects.
This repo contains a Requests session that returns awaitable Twisted Deferreds instead of Response objects.
It’s awesome, basically — check it out:
Example Usage (using async/await):
from requests_threads import AsyncSession session = AsyncSession() async def _main(): rs =  for _ in range(100): rs.append(await session.get('http://httpbin.org/get')) print(rs) if __name__ == '__main__': session.run(_main)
This example works on Python 3 only.
Example Usage (using Twisted):
from twisted.internet.defer import inlineCallbacks from twisted.internet.task import react import requests session = requests.AsyncSession(n=100) @inlineCallbacks def main(reactor): responses =  for i in range(100): responses.append(session.get('http://httpbin.org/get')) for response in responses: r = yield response print(r) if __name__ == '__main__': react(main)
This example works on Python 2 and Python 3.
Each request is sent via a new thread, automatically. This works fine for basic use cases. This automatically uses Twisted’s asyncioreactor, if you do not provide your own reactor (progress to be made there, help requested!).
This is a an experiment, and a preview of the true asyncronous API we have panned for Requests that is currently in the works, but requires a lot of development time. If you’d like to help (p.s. we need help, send me an email).
This API is likely to change, over time, slightly.
$ pipenv install requests-threads ✨🍰✨
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
|Filename, size||File type||Python version||Upload date||Hashes|
|Filename, size requests_threads-0.1.1-py2.py3-none-any.whl (4.8 kB)||File type Wheel||Python version py2.py3||Upload date||Hashes View|
|Filename, size requests-threads-0.1.1.tar.gz (3.7 kB)||File type Source||Python version None||Upload date||Hashes View|
Hashes for requests_threads-0.1.1-py2.py3-none-any.whl