Skip to main content

Easy Cache using local files, in memory, or MongoDB.

Project description

Pi Cache

A flexible file-based caching system for Python functions with support for complex data types and configurable caching behavior.

Installation

pip install pi-cache

Features

  • File-based persistent caching
  • Support for complex Python objects and Pydantic models
  • Configurable cache expiration
  • Parameter-based cache key generation
  • Metadata tracking for cached entries
  • Thread-safe operations

Quick Start

from pi_cache import local_cache
from datetime import datetime

@local_cache(expiration="1d")  # Cache for 1 day
def get_user_data(user_id: int):
    # Expensive database query or API call
    return {"id": user_id, "last_fetch": datetime.now()}

# First call: executes function
result = get_user_data(123)

# Second call: returns cached result
cached_result = get_user_data(123)

Advanced Usage

Custom Cache Settings

from pi_cache import local_cache, FileCacheSettings, TimeCheck
from pathlib import Path

settings = FileCacheSettings(
    cache_dir=Path("./my_cache"),
    expiration="12h",
    time_check=TimeCheck.LAST_UPDATE,
    return_metadata_as_member=True
)

@local_cache(settings=settings)
def expensive_computation(x: int, y: int):
    return x * y

Cache Only Specific Parameters

@local_cache(
    key_parameters=['user_id'],  # Only cache based on user_id
    expiration="30m"
)
def get_user_posts(user_id: int, include_drafts: bool = False):
    # API call
    return [{"post_id": 1, "content": "Hello"}]

Working with Pydantic Models

from pydantic import BaseModel

class UserData(BaseModel):
    id: int
    name: str
    email: str

@local_cache(expiration="1h")
def fetch_user(user_id: int) -> UserData:
    # Database query
    return UserData(id=user_id, name="John", email="john@example.com")

Accessing Cache Metadata

@local_cache(return_metadata_as_member=True)
def compute_stats(data: list[int]):
    result = sum(data)
    return {"sum": result}

stats = compute_stats([1, 2, 3])
print(f"Cached at: {stats._metadata.creation_timestamp}")

Cache Only Mode

@local_cache(cache_only=True)
def api_call(endpoint: str):
    # Will raise CacheMissError if not in cache
    pass

try:
    result = api_call("/users")
except CacheMissError:
    # Handle cache miss
    pass

API Reference

Decorators

  • @local_cache(): Main decorator for caching functions

Settings

FileCacheSettings parameters:

  • cache_dir: str | Path - Cache directory location
  • expiration: Optional[str | int] - Cache expiration time
  • key_parameters: Optional[list[str]] - Parameters to use for cache key
  • time_check: TimeCheck - Validation time check method
  • return_metadata_as_member: bool - Attach metadata to returned objects
  • return_metadata_on_primitives: bool - Include metadata with primitive returns
  • cache_only: bool - Only use cache, don't execute function

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

License

MIT

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

pi_cache-0.5.5.tar.gz (18.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pi_cache-0.5.5-py3-none-any.whl (17.0 kB view details)

Uploaded Python 3

File details

Details for the file pi_cache-0.5.5.tar.gz.

File metadata

  • Download URL: pi_cache-0.5.5.tar.gz
  • Upload date:
  • Size: 18.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.5.13

File hashes

Hashes for pi_cache-0.5.5.tar.gz
Algorithm Hash digest
SHA256 0880e46ba0a0019f9a589f2b3f250a74ceefe67aaf410b59267bf489a406dd50
MD5 e23a4d619764ee19304e4708cc7b66f3
BLAKE2b-256 75940bd2a835b0db89493c2aea020388f6552f0b4228ca692e433a9aaeabf20c

See more details on using hashes here.

File details

Details for the file pi_cache-0.5.5-py3-none-any.whl.

File metadata

  • Download URL: pi_cache-0.5.5-py3-none-any.whl
  • Upload date:
  • Size: 17.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.5.13

File hashes

Hashes for pi_cache-0.5.5-py3-none-any.whl
Algorithm Hash digest
SHA256 c0f95ecc831790214d960cf74242392b670efdc0cdbcbcd1cd208dd5af63dfe9
MD5 d42319895e2ca010e13e7cf1f866c1da
BLAKE2b-256 59fdcfd71a17df13a4cc68005262451d2ea6f80d3ff4d6fa1ef53e680201a74c

See more details on using hashes here.

Supported by

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