Skip to main content

A Python library that captures and replays function results to save time, boost performance.

Project description

resnap logo

resnap

Smart function output snapshots and caching for Python
resnap snapshots and reuses function outputs based on their inputs, saving time with smart caching and metadata tracking.


Lint Tests

🚀 Features

  • Snapshot and cache function/method outputs on disk
  • Avoid re-executing code when inputs haven’t changed
  • Supports multiple formats:
    • For pd.DataFrame objects: parquet (default) and csv
    • For other objects: pkl (default), json, and txt.
      (Note that for the "json" format, the object type must be compatible with the json.dump method.)
  • Stores metadata automatically
  • Add custom metadata
  • Minimal setup, flexible usage

📦 Installation

To test in local mode

pip install resnap

If you want to use a S3 solution

pip install resnap[boto]

🛠️ Configuration

To use this library, you need to configure it using a pyproject.toml file. Add the following section under [tool.resnap]:

[tool.resnap]
enabled = true                          # Enable or disable the library functionality
save_to = "local"                       # Choose the storage backend (e.g., 'local')
output_base_path = "results"            # Directory where output files will be saved
secrets_file_name = ""                  # Optional: path to a secrets file (leave empty if unused (e.g, 'local'))
enable_remove_old_files = true          # Automatically delete old files based on retention policy
max_history_files_length = 3            # Duration value for file retention, used with max_history_files_time_unit
max_history_files_time_unit = "day"     # Time unit used for history retention (e.g., 'second', 'minute', 'hour', 'day')

🧪 Quick Example

from resnap import resnap

@resnap
def expensive_computation(x, y):
    print("Running the actual computation...")
    return x * y + 42

result = expensive_computation(10, 2)

Second call with same arguments:

# Output is retrieved from cache — no print, no computation
result = expensive_computation(10, 2)

📁 Output Structure

Each snapshot includes:

  • A result file (in the format of your choice)
  • A metadata file (e.g., timestamp, arguments, execution time, etc.)

📚 Documentation

Documentation

🛡️ License

This project is licensed under the MIT License. See the LICENSE file for details.

🤝 Contributing

Contributions, issues and feature requests are welcome! Feel free to open a PR or start a discussion.

⭐️ Show your support If you find this project useful, give it a ⭐️ on GitHub!

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

resnap-0.1.0.tar.gz (637.0 kB view details)

Uploaded Source

Built Distribution

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

resnap-0.1.0-py3-none-any.whl (26.8 kB view details)

Uploaded Python 3

File details

Details for the file resnap-0.1.0.tar.gz.

File metadata

  • Download URL: resnap-0.1.0.tar.gz
  • Upload date:
  • Size: 637.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.7.6

File hashes

Hashes for resnap-0.1.0.tar.gz
Algorithm Hash digest
SHA256 3bf9a7b76252f8a01a4127c0661d4a2b0ee7a6f824751b05bfdf233e00285fe9
MD5 141f051aff04c077d2be1efb8cf540a2
BLAKE2b-256 7ac2da75ec090b8acd0a20e66b7ac93049997c0de642757df91b59abb75c62e7

See more details on using hashes here.

File details

Details for the file resnap-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: resnap-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 26.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.7.6

File hashes

Hashes for resnap-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 dce81d8620b9de35220e9a087f008718433e1c27ef855dcb0331e528ef0f0196
MD5 279df751d8ae850753135b5cef5480fc
BLAKE2b-256 c2cdca63e2c0a2b0ac9a88f07b477b3eef677957d2cce57f5f211b725d5733ef

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