rediswrapper is a pythonic wrapper of Redis Client for end users. The whole storage acts like a python dict as well as its child storage values.
- The root client support dict-like operations
- Python object wrappers for list, set, hash type values
- Implicit serialization and deserialization when storing and fetching data
From PyPI:
pip install rediswrapper
From GitHub:
git clone https://github.com/frostming/rediswrapper cd rediswrapper python setup.py install
rediswrapper
will try to serialize non-sting values and store them in redis and
deserialize them when fetching back.
All redis value types are mocked with respective python objects and support all standard methods as the builtin types.
>>> import rediswrapper
>>> redis = rediswrapper.RedisDict()
# String value
>>> redis['a'] = 'hello'
# int value
>>> redis['b'] = 2
>>> dict(redis)
{'a': 'hello', 'b': 2}
# Picklable object
>>> import datetime
>>> redis['c'] = datetime.datetime.now()
# List value
>>> redis['d'] = list(range(5))
>>> redis['d'].append(0)
>>> redis['d']
ListType value([0, 1, 2, 3, 4, 0])
# Hash value
>>> redis['e'] = {'a': 1, 'b': 2}
>>> redis['e'].get('a')
1
# Set value
>>> redis['f'] = set([1, 2])
>>> redis['f'].add(3)
>>> redis['f']
SetType value([1, 2, 3])
To inspect those value types, one should use the ABCs defined in collections
module.
>>> from collections import Mapping
>>> isinstance(redis['e'], Mapping)
True
- v0.3.0
- Drop support for Python 3.3
- Fix a vulnerability issue that cause users run arbitrary scripts.
This work is open-sourced under the MIT license.