Skip to main content

Feature collection storage for DossierStack

Project description

`dossier.store` is a Python package that provides database storage for
feature collections in DossierStack. It is built on top of `kvlayer`, so
it supports many database backends like PostgreSQL, Accumulo and Redis.
`dossier.store` also provides support for defining basic indexes.


### Installation

`dossier.store` is on PyPI and can be installed with `pip`:

```bash
pip install dossier.store
```

Currently, `dossier.store` requires Python 2.7. It is not yet Python 3
compatible.


### Documentation

API documentation with examples is available as part of the Dossier Stack
documentation:
[http://dossier-stack.readthedocs.org](http://dossier-stack.readthedocs.org#module-dossier.store)


### Basic example

A full working example that uses local memory to store a feature collection:

```python
from dossier.fc import FeatureCollection
from dossier.store import Store
import kvlayer
import yakonfig

yaml = """
kvlayer:
app_name: store
namespace: dossier
storage_type: local
"""
with yakonfig.defaulted_config([kvlayer], yaml=yaml):
store = Store(kvlayer.client())

fc = FeatureCollection({u'NAME': {'Foo': 1, 'Bar': 2}})
store.put([('1', fc)])
print store.get('1')
```


### Example using indexes

Here is another example that demonstrates use of indexing to enable a
poor man's case insensitive search:

```python
fc = dossier.fc.FeatureCollection()
fc[u'NAME'][u'foo'] += 1
fc[u'NAME'][u'bar'] = 42

kvl = kvlayer.client()
store = dossier.store.Store(kvl)

# Index transforms must be defined on every instance of `Store`.
# (The index data is persisted; the transforms themselves are
# ephemeral.)
store.define_index(u'name_casei',
create=feature_index(u'NAME'),
transform=lambda s: s.lower().encode('utf-8'))

store.put('{yourid}', fc) # `put` automatically updates indexes.
assert list(store.index_scan(u'name_casei', 'FoO'))[0] == '{yourid}'
```

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

dossier.store-0.5.0.tar.gz (23.4 kB view details)

Uploaded Source

Built Distribution

dossier.store-0.5.0-py2.7.egg (54.1 kB view details)

Uploaded Source

File details

Details for the file dossier.store-0.5.0.tar.gz.

File metadata

File hashes

Hashes for dossier.store-0.5.0.tar.gz
Algorithm Hash digest
SHA256 104504f3792c4ab17aeb65dc222d6206c439c54937d8fa82d237c2fa1e907bd8
MD5 37a0bbf865552d807fef1f3a7ddd70e9
BLAKE2b-256 914327e2a5fbaddae9249401da0a3db0d53d967fc5f29793dae769d36c3eb2b6

See more details on using hashes here.

File details

Details for the file dossier.store-0.5.0-py2.7.egg.

File metadata

File hashes

Hashes for dossier.store-0.5.0-py2.7.egg
Algorithm Hash digest
SHA256 ed9ed4fb38c671fbb045217cfc900090ec8358662f77e06ef60b9d92439d2a93
MD5 b31813d303825a34ed5a7cef3e2ec24a
BLAKE2b-256 0be6cbc6c7d28790667d3fa8fd9bf8db8b03a11eefca775b337664ca03a94726

See more details on using hashes here.

Supported by

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