Skip to main content

QuickSave is a fast, memory-efficient, and lightweight key-value database.

Project description

QuickSave Banner

QuickSave

Python Version PyPI Version License Total Downloads

QuickSave is a fast, memory-efficient, and lightweight key-value database designed for use in small applications. It operates as a pure Python solution, offering a dictionary-like interface for easy integration. QuickSave works efficiently without dependencies, but if you want to boost its performance even further, you can install msgspec, which significantly enhances its speed.


Documentation

📖 Table of Contents


Why QuickSave?

QuickSave stands out for its speed, memory efficiency, and simplicity. Here are some of the key reasons you should consider using it:

  • 🚀 High Performance: QuickSave is designed to be fast, with minimal overhead.
  • 💡 Low Memory Usage: The library is optimized for memory efficiency, making it a great choice for projects with limited resources.
  • 🧵 Thread-Safe: It supports thread-safe operations, ensuring that it works reliably in concurrent environments.
  • 🔀 Both sync and async support: You can use either sync or async version of QuickSave.
  • 🏎️ Boosted Performance with msgspec: By installing the optional msgspec library, you can further enhance QuickSave's performance, especially when handling complex data types.
  • 🔧 No Dependencies: QuickSave is a pure Python library, which means it has no external dependencies, making it easy to install and use in any Python project.

Installation

Install QuickSave using pip:

pip install --upgrade qsave

Optionally, install msgspec to boost performance:

pip install msgspec==0.19.0

If you want use async version of QuickSave:

pip install qsave[async]

Getting Started

To start using QuickSave, import it and initialize your database:

from qsave import QuickSave

db = QuickSave(path="path/to/your/file.json", pretty=True)

The pretty argument beautifies the saved data for better readability (optional).


Examples

Basic Usage

By default, changes are automatically saved when the with block ends:

with db.session() as session:
    session["key"] = "value"
    print(session.get("key"))  # Output: None, not yet saved

# Exiting the block automatically commits changes
with db.session() as session:
    print(session.get("key"))  # Output: value

Manual Commit (commit_on_expire=False)

For full control over when changes are saved, use commit_on_expire=False:

with db.session(commit_on_expire=False) as session:
    session["key"] = "manual_value"
    print(session.get("key"))  # Output: None, not yet saved
    session.commit()  # Now changes are saved
    print(session.get("key"))  # Output: manual_value

with db.session() as session:
    print(session.get("key"))  # Output: manual_value

Commit and Rollback

You can manually save or discard changes during a session:

with db.session() as session:
    session["key"] = "temp_value"
    session.rollback()  # Discard changes
    print(session.get("key"))  # Output: None

Nested Data

with db.session() as session:
    session["nested"] = {"key": [1, 2, 3]}
    session.commit()

with db.session() as session:
    print(session["nested"])  # Output: {"key": [1, 2, 3]}

Async version:

from qsave.asyncio import AsyncQuickSave

db = AsyncQuickSave("path/to/your/file.json")

async def main():
    async with db.session(False) as session:
        print(len(session))
        await session.commit()
        await session.rollback()  # NOTE: after commit, rollback does nothing :(
        # only commit and rollback need to be awaited
        # other functionalities remain the same as sync version

License

This repository is licensed under MIT License.

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

qsave-1.1.1.tar.gz (5.6 kB view details)

Uploaded Source

Built Distribution

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

qsave-1.1.1-py3-none-any.whl (9.1 kB view details)

Uploaded Python 3

File details

Details for the file qsave-1.1.1.tar.gz.

File metadata

  • Download URL: qsave-1.1.1.tar.gz
  • Upload date:
  • Size: 5.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.0.0 CPython/3.11.6 Windows/10

File hashes

Hashes for qsave-1.1.1.tar.gz
Algorithm Hash digest
SHA256 8f2ef4c00203331c19610423a5d496388b76e27b224bbe937fabf7339c1726c0
MD5 5fbbfbe08023aff9a8910f6429e633d6
BLAKE2b-256 e70380e9aa6ddda1341bf18adc08f08dfa09f412a699bd89dbb7236eaed0e8ad

See more details on using hashes here.

File details

Details for the file qsave-1.1.1-py3-none-any.whl.

File metadata

  • Download URL: qsave-1.1.1-py3-none-any.whl
  • Upload date:
  • Size: 9.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.0.0 CPython/3.11.6 Windows/10

File hashes

Hashes for qsave-1.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 388678b25614a63a44fd0a11822c427ed67c321c7c15563ddaed9655ce788837
MD5 dcfd7e2033f6562ba483c9d3fd7f0894
BLAKE2b-256 8e95ce51ddfd64574fa81f1de1e3fa2b5e2a0c70762abcd4d65f0775fae8351b

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