Skip to main content

No project description provided

Project description

Introduction

This library allows you to access blobs via Pythonic dict-like interface. Note that due to the nature of blob, not all dict methods are implemented. Therefore, it is not a subclass of MutableMapping type.

Supported Blob Dict Methods

Specifically, for a blob dict d, the following methods are available:

  • len(d)
  • key in d
  • d.get(key, default)
  • d[key]
  • for key in d:
  • d.pop(key, default)
  • del d[key]
  • d[key] = blob

Supported Blob Dict Types

There are different blob dict implementations:

  • InMemoryBlobDict for in-memory storage, with optional TTL
  • PathBlobDict for specified folder on file system as storage, with relative file path as key
    • It supports local file systems via PathLib
      • Ideally use provided LocalPath class (which is a subclass of Path) for full support
    • It also supports cloud file systems (like AWS S3 (and competible Cloudflare R2), Azure Blob Storage, and Google Cloud Storage) via CloudPathLib
  • GitBlobDict for specified Git repo on file system as storage, with relative file path as key
    • It auto commits any add/update/delete
    • It auto syncs with remote if enabled
    • Optionally, key can be tuple where the second part is version:
      • str for version at specified commit/tag, like HEAD~2
      • int for relative version (same way of Python sequence index) of file, like 0 for first version and -2 for previous version
      • datetime for latest version before specified date/time
      • timedelta for latest version of specified duration before now
  • VulkeyBlobDict for Vulkey/Redis-based storage, with optional TTL
  • Specially, MultiReplicaBlobDict for utilizing multiple blob dicts underneath
    • For example, you can use in-memory or local file system blob dict as cache layer, while any cloud file system blob dict as storage

Supported Blob Types

There as many types of blobs with following class hierarchy relationship:

  • BytesBlob for any data
    • StrBlob for any string
      • JsonDictBlob for any JSON dict object
      • JsonModelBlob for any Pydantic model object
    • AudioBlob for any SoundFile audio data
    • ImageBlob for any PIL/Pillow image data
    • VideoBlob for any MoviePy video clip data

Ultimately, all data are persisted as bytes.

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

blob_dict-0.1.16.tar.gz (123.5 kB view details)

Uploaded Source

Built Distribution

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

blob_dict-0.1.16-py3-none-any.whl (14.8 kB view details)

Uploaded Python 3

File details

Details for the file blob_dict-0.1.16.tar.gz.

File metadata

  • Download URL: blob_dict-0.1.16.tar.gz
  • Upload date:
  • Size: 123.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.14

File hashes

Hashes for blob_dict-0.1.16.tar.gz
Algorithm Hash digest
SHA256 c314fa6b103b17a7e9c33c63f1b5340f49df189f44e63ca015359d944ac3e051
MD5 7f80709f91385aff6896c1944430f16f
BLAKE2b-256 73752f273067df4211b1c956501f7f8d94f0cc8e312e0525428efa01235d9d86

See more details on using hashes here.

File details

Details for the file blob_dict-0.1.16-py3-none-any.whl.

File metadata

  • Download URL: blob_dict-0.1.16-py3-none-any.whl
  • Upload date:
  • Size: 14.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.14

File hashes

Hashes for blob_dict-0.1.16-py3-none-any.whl
Algorithm Hash digest
SHA256 556449da6d61169ea1ebe815cd80d963b581a5c888f21b42318f753eafe9907a
MD5 9e0ecca01c650acde3e15fbe615f9305
BLAKE2b-256 0edc33c0d4b74aa144927276c044ae8e98bd3383635175eb6c4039fa86b0ce59

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