Merge pull request #311 from JWCook/type-hints

Finish type annotations and PEP-561 compliance
tree: d1535ee72763463d06430249ce1e578b8ab36747
  1. .github/
  2. docs/
  3. examples/
  4. requests_cache/
  5. tests/
  6. .gitignore
  7. .readthedocs.yml
  8. CODESHELTER.md
  9. CONTRIBUTING.md
  10. CONTRIBUTORS.md
  11. docker-compose.yml
  12. HISTORY.md
  13. LICENSE
  14. poetry.lock
  15. pyproject.toml
  16. README.md
  17. runtests.sh
  18. setup.cfg
README.md

Requests-Cache

Build Coverage Documentation PyPI PyPI - Python Versions PyPI - Format Code Shelter

Summary

requests-cache is a transparent, persistent HTTP cache for the python requests library. It‘s a convenient tool to use with web scraping, consuming REST APIs, slow or rate-limited sites, or any other scenario in which you’re making lots of requests that are expensive and/or likely to be sent more than once.

See full project documentation at: https://requests-cache.readthedocs.io

Features

Quickstart

First, install with pip:

pip install requests-cache

Next, use requests_cache.CachedSession to send and cache requests. To quickly demonstrate how to use it:

This takes ~1 minute:

import requests

session = requests.Session()
for i in range(60):
    session.get('http://httpbin.org/delay/1')

This takes ~1 second:

import requests_cache

session = requests_cache.CachedSession('demo_cache')
for i in range(60):
    session.get('http://httpbin.org/delay/1')

The URL in this example adds a delay of 1 second, simulating a slow or rate-limited website. With caching, the response will be fetched once, saved to demo_cache.sqlite, and subsequent requests will return the cached response near-instantly.

If you don't want to manage a session object, requests-cache can also be installed globally:

requests_cache.install_cache('demo_cache')
requests.get('http://httpbin.org/delay/1')

Next Steps

To find out more about what you can do with requests-cache, see: