requests-cache 1.2.1


pip install requests-cache

  Latest version

Released: Jun 18, 2024


Meta
Author: Roman Haritonov
Requires Python: >=3.8

Classifiers

Development Status
  • 5 - Production/Stable

Intended Audience
  • Developers

License
  • OSI Approved :: BSD License

Programming Language
  • Python :: 3
  • Python :: 3.8
  • Python :: 3.9
  • Python :: 3.10
  • Python :: 3.11
  • Python :: 3.12

Topic
  • Software Development :: Libraries :: Python Modules

Typing
  • Typed

Build Codecov Documentation Code Shelter

PyPI Conda PyPI - Python Versions PyPI - Downloads

Summary

requests-cache is a persistent HTTP cache that provides an easy way to get better performance with the python requests library.

Complete project documentation can be found at requests-cache.readthedocs.io.

Features

  • ๐Ÿฐ Ease of use: Keep using the requests library you're already familiar with. Add caching with a drop-in replacement for requests.Session, or install globally to add transparent caching to all requests functions.
  • ๐Ÿš€ Performance: Get sub-millisecond response times for cached responses. When they expire, you still save time with conditional requests.
  • ๐Ÿ’พ Persistence: Works with several storage backends including SQLite, Redis, MongoDB, and DynamoDB; or save responses as plain JSON files, YAML, and more
  • ๐Ÿ•— Expiration: Use Cache-Control and other standard HTTP headers, define your own expiration schedule, keep your cache clutter-free with backends that natively support TTL, or any combination of strategies
  • โš™๏ธ Customization: Works out of the box with zero config, but with a robust set of features for configuring and extending the library to suit your needs
  • ๐Ÿงฉ Compatibility: Can be combined with other popular libraries based on requests

Quickstart

First, install with pip:

pip install requests-cache

Then, use requests_cache.CachedSession to make your requests. It behaves like a normal requests.Session, but with caching behavior.

To illustrate, we'll call an endpoint that adds a delay of 1 second, simulating a slow or rate-limited website.

This takes 1 minute:

import requests

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

This takes 1 second:

import requests_cache

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

With caching, the response will be fetched once, saved to demo_cache.sqlite, and subsequent requests will return the cached response near-instantly.

Patching

If you don't want to manage a session object, or just want to quickly test it out in your application without modifying any code, requests-cache can also be installed globally, and all requests will be transparently cached:

import requests
import requests_cache

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

Headers and Expiration

By default, requests-cache will keep cached responses indefinitely. In most cases, you will want to use one of the two following strategies to balance cache freshness and performance:

Define exactly how long to keep responses:

Use the expire_after parameter to set a fixed expiration time for all new responses:

from requests_cache import CachedSession
from datetime import timedelta

# Keep responses for 360 seconds
session = CachedSession('demo_cache', expire_after=360)

# Or use timedelta objects to specify other units of time
session = CachedSession('demo_cache', expire_after=timedelta(hours=1))

See Expiration for more features and settings.

Use Cache-Control headers:

Use the cache_control parameter to enable automatic expiration based on Cache-Control and other standard HTTP headers sent by the server:

from requests_cache import CachedSession

session = CachedSession('demo_cache', cache_control=True)

See Cache Headers for more details.

Settings

The default settings work well for most use cases, but there are plenty of ways to customize caching behavior when needed. Here is a quick example of some of the options available:

from datetime import timedelta
from requests_cache import CachedSession

session = CachedSession(
    'demo_cache',
    use_cache_dir=True,                # Save files in the default user cache dir
    cache_control=True,                # Use Cache-Control response headers for expiration, if available
    expire_after=timedelta(days=1),    # Otherwise expire responses after one day
    allowable_codes=[200, 400],        # Cache 400 responses as a solemn reminder of your failures
    allowable_methods=['GET', 'POST'], # Cache whatever HTTP methods you want
    ignored_parameters=['api_key'],    # Don't match this request param, and redact if from the cache
    match_headers=['Accept-Language'], # Cache a different response per language
    stale_if_error=True,               # In case of request errors, use stale cache data if possible
)

Next Steps

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

1.3.0a1 Sep 27, 2025
1.3.0a0 Feb 25, 2025
1.2.1 Jun 18, 2024
1.2.0 Feb 17, 2024
1.1.1 Nov 19, 2023
1.1.0 Jun 30, 2023
1.0.1 Mar 25, 2023
1.0.0 Mar 02, 2023
1.0.0b1 Jan 13, 2023
1.0.0b0 Sep 29, 2022
1.0.0a2 Aug 24, 2022
1.0.0a1 Jun 12, 2022
1.0.0a0 May 07, 2022
0.9.8 Jan 13, 2023
0.9.7 Oct 26, 2022
0.9.6 Aug 24, 2022
0.9.5 Jun 29, 2022
0.9.4 Apr 23, 2022
0.9.3 Feb 23, 2022
0.9.2 Feb 15, 2022
0.9.1 Jan 15, 2022
0.9.0 Jan 01, 2022
0.8.1 Sep 15, 2021
0.8.0 Sep 07, 2021
0.7.5 Sep 15, 2021
0.7.4 Aug 16, 2021
0.7.3 Aug 10, 2021
0.7.2 Jul 21, 2021
0.7.1 Jul 10, 2021
0.7.0 Jul 07, 2021
0.6.4 Jun 05, 2021
0.6.3 Apr 21, 2021
0.6.2 Apr 14, 2021
0.6.1 Apr 13, 2021
0.6.0 Apr 09, 2021
0.5.2 Aug 14, 2019
0.5.1 Aug 13, 2019
0.5.0 Apr 18, 2019
0.4.13 Dec 23, 2016
0.4.12 Mar 19, 2016
0.4.11 Mar 07, 2016
0.4.10 Apr 28, 2015
0.4.9 Jan 17, 2015
0.4.8 Dec 13, 2014
0.4.7 Dec 06, 2014
0.4.6 Oct 13, 2014
0.4.5 Aug 22, 2014
0.4.4 Oct 31, 2013
0.4.3 Sep 12, 2013
0.4.2 Aug 25, 2013
0.4.1 Aug 19, 2013
0.4.0 Apr 25, 2013
0.3.0 Feb 24, 2013
0.2.1 Jan 13, 2013
0.2.0 Jan 12, 2013
0.1.3 May 04, 2012
0.1.2 May 02, 2012
0.1.1 Apr 11, 2012
0.1.0 Apr 10, 2012
0.4.9.win32 Jan 17, 2015
0.4.8.win32 Dec 13, 2014
0.4.7.win32 Dec 06, 2014
0.4.6.win32 Oct 13, 2014
0.4.5.win32 Aug 22, 2014
0.4.4.win32 Oct 31, 2013
0.4.3.win32 Sep 12, 2013
0.4.2.win32 Aug 25, 2013
0.4.10.win32 Apr 28, 2015
0.4.1.win32 Aug 19, 2013
0.4.0.win32 Apr 25, 2013
0.3.0.win32 Feb 24, 2013
0.2.1.win32 Jan 13, 2013
0.2.0.win32 Jan 12, 2013
0.1.3.win32 May 04, 2012
0.1.2.win32 May 02, 2012
0.1.1.win32 Apr 11, 2012
0.1.0.win32 Apr 10, 2012

Wheel compatibility matrix

Platform Python 3
any

Files in release

Extras:
Dependencies:
attrs (>=21.2)
cattrs (>=22.2)
platformdirs (>=2.5)
requests (>=2.22)
url-normalize (>=1.4)
urllib3 (>=1.25.5)