Skip to main content

Persistent dict in Python, backed up by sqlite3 and pickle, multithread-safe.

Project description

A lightweight wrapper around Python’s sqlite3 database, with a dict-like interface and multi-thread access support:

>>> mydict = SqliteDict('some.db', autocommit=True) # the mapping will be persisted to file `some.db`
>>> mydict['some_key'] = any_picklable_object
>>> print mydict['some_key']
>>> print len(mydict) # etc... all dict functions work

Pickle is used internally to serialize the values. Keys are strings.

If you don’t use autocommit (default is no autocommit for performance), then don’t forget to call mydict.commit() when done with a transaction.

Features

  • Values can be any picklable objects (uses cPickle with the highest protocol).

  • Support for multiple tables (=dicts) living in the same database file.

  • Support for access from multiple threads to the same connection (needed by e.g. Pyro). Vanilla sqlite3 gives you ProgrammingError: SQLite objects created in a thread can only be used in that same thread.

Concurrent requests are still serialized internally, so this “multithreaded support” doesn’t give you any performance benefits. It is a work-around for sqlite limitations in Python.

Installation

The module has no dependencies beyond 2.5 <= Python < 3.0. Install or upgrade with:

sudo easy_install -U sqlitedict

or from the source tar.gz

python sqlitedict.py # run some tests
sudo python setup.py install

Documentation

Standard Python document strings are inside the module:

>>> import sqlitedict
>>> help(sqlitedict)

(but it’s just dict with a commit, really).

Comments, bug reports

sqlitedict resides on github. You can file issues or pull requests there.


sqlitedict is released as public domain, you may do with it as you please. Hack away.

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

sqlitedict-1.0.4.tar.gz (5.5 kB view details)

Uploaded Source

File details

Details for the file sqlitedict-1.0.4.tar.gz.

File metadata

  • Download URL: sqlitedict-1.0.4.tar.gz
  • Upload date:
  • Size: 5.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for sqlitedict-1.0.4.tar.gz
Algorithm Hash digest
SHA256 3937f2c02a6c47493c6b81c6177b9b7ee7026edf37f13fcf846138c2e6953604
MD5 e9c44964612c86e2e131b77168a4dc77
BLAKE2b-256 b49ba3b2d005103b5d8c77f0d97de92e894658898d66b64de5a8bde400e632c7

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