.. image:: https://img.shields.io/pypi/v/jaraco.modb.svg
:target: https://pypi.org/project/jaraco.modb
.. image:: https://img.shields.io/pypi/pyversions/jaraco.modb.svg
.. image:: https://github.com/jaraco/jaraco.modb/workflows/tests/badge.svg
:target: https://github.com/jaraco/jaraco.modb/actions?query=workflow%3A%22tests%22
:alt: tests
.. image:: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/charliermarsh/ruff/main/assets/badge/v2.json
:target: https://github.com/astral-sh/ruff
:alt: Ruff
.. image:: https://img.shields.io/badge/code%20style-black-000000.svg
:target: https://github.com/psf/black
:alt: Code style: Black
.. .. image:: https://readthedocs.org/projects/PROJECT_RTD/badge/?version=latest
.. :target: https://PROJECT_RTD.readthedocs.io/en/latest/?badge=latest
.. image:: https://img.shields.io/badge/skeleton-2023-informational
:target: https://blog.jaraco.com/skeleton
``jaraco.modb`` is a small, pure-Python library for persisting Python
objects to `MongoDB <https://www.mongodb.org/>`_.
Manual Usage
============
``jaraco.modb`` facilitates using `jsonpickle` to produce MongoDB-friendly
representations of pickleable Python objects for easy storage in a MongoDB
database.
One may simply encode and decode Python objects to MongoDB
BSON-friendly representations::
class MyObject(object):
def __init__(self, val):
self.val = val
import jaraco.modb
import pymongo
mongo_collection = pymongo.MongoClient().mydb.mycollection
val = MyObject(3)
# save the object to the DB
id = mongo_collection.save(jaraco.modb.encode(val))
# retrieve the object from the DB
new_val = jaraco.modb.decode(mongo_collection.find_one(id))
assert isinstance(new_val, MyObject)
assert new_val.val == 3
A more detailed tutorial is now `published as a Jupyter Notebook
<https://nbviewer.jupyter.org/github/jaraco/jaraco.modb/blob/master/tutorial.ipynb>`_.
Automatic Usage
===============
``jaraco.modb`` also provides an SON Manipulator suitable for automatically
encoding arbitrary objects for a pymongo.Database::
jaraco.modb.SONManipulator.install(mongo_collection.database)
mongo_collection.save({'val': val})
Unfortunately, due to a limitation with the API of the SONManipulator,
it's not possible to save a custom object as the document itself (the
document must always be a dict).
Raw data
{
"_id": null,
"home_page": "https://github.com/jaraco/jaraco.modb",
"name": "jaraco.modb",
"maintainer": "",
"docs_url": null,
"requires_python": ">=3.8",
"maintainer_email": "",
"keywords": "",
"author": "Jason R. Coombs",
"author_email": "jaraco@jaraco.com",
"download_url": "https://files.pythonhosted.org/packages/be/c4/d93330b6f0d93b78d6644dc926fe7c07c3d3314b891df5ed2e53a25ccb6f/jaraco.modb-6.1.0.tar.gz",
"platform": null,
"description": ".. image:: https://img.shields.io/pypi/v/jaraco.modb.svg\n :target: https://pypi.org/project/jaraco.modb\n\n.. image:: https://img.shields.io/pypi/pyversions/jaraco.modb.svg\n\n.. image:: https://github.com/jaraco/jaraco.modb/workflows/tests/badge.svg\n :target: https://github.com/jaraco/jaraco.modb/actions?query=workflow%3A%22tests%22\n :alt: tests\n\n.. image:: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/charliermarsh/ruff/main/assets/badge/v2.json\n :target: https://github.com/astral-sh/ruff\n :alt: Ruff\n\n.. image:: https://img.shields.io/badge/code%20style-black-000000.svg\n :target: https://github.com/psf/black\n :alt: Code style: Black\n\n.. .. image:: https://readthedocs.org/projects/PROJECT_RTD/badge/?version=latest\n.. :target: https://PROJECT_RTD.readthedocs.io/en/latest/?badge=latest\n\n.. image:: https://img.shields.io/badge/skeleton-2023-informational\n :target: https://blog.jaraco.com/skeleton\n\n\n``jaraco.modb`` is a small, pure-Python library for persisting Python\nobjects to `MongoDB <https://www.mongodb.org/>`_.\n\nManual Usage\n============\n\n``jaraco.modb`` facilitates using `jsonpickle` to produce MongoDB-friendly\nrepresentations of pickleable Python objects for easy storage in a MongoDB\ndatabase.\n\nOne may simply encode and decode Python objects to MongoDB\nBSON-friendly representations::\n\n class MyObject(object):\n def __init__(self, val):\n self.val = val\n\n import jaraco.modb\n import pymongo\n mongo_collection = pymongo.MongoClient().mydb.mycollection\n val = MyObject(3)\n # save the object to the DB\n id = mongo_collection.save(jaraco.modb.encode(val))\n # retrieve the object from the DB\n new_val = jaraco.modb.decode(mongo_collection.find_one(id))\n assert isinstance(new_val, MyObject)\n assert new_val.val == 3\n\nA more detailed tutorial is now `published as a Jupyter Notebook\n<https://nbviewer.jupyter.org/github/jaraco/jaraco.modb/blob/master/tutorial.ipynb>`_.\n\n\nAutomatic Usage\n===============\n\n``jaraco.modb`` also provides an SON Manipulator suitable for automatically\nencoding arbitrary objects for a pymongo.Database::\n\n jaraco.modb.SONManipulator.install(mongo_collection.database)\n mongo_collection.save({'val': val})\n\nUnfortunately, due to a limitation with the API of the SONManipulator,\nit's not possible to save a custom object as the document itself (the\ndocument must always be a dict).\n",
"bugtrack_url": null,
"license": "",
"summary": "MongoDB Object DataBase (MODB) for Python objects",
"version": "6.1.0",
"project_urls": {
"Homepage": "https://github.com/jaraco/jaraco.modb"
},
"split_keywords": [],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "98413e8ffe61520c112fc740b57a3f24c36429d3bac83cfac782e8cd89cc2ee5",
"md5": "132adfc277061d0ccd16c1deb186889d",
"sha256": "fc59eb0e81ef1a6964102813adb9b23129c6401b8dfcddd5c20497ead23c4b12"
},
"downloads": -1,
"filename": "jaraco.modb-6.1.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "132adfc277061d0ccd16c1deb186889d",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.8",
"size": 3644,
"upload_time": "2023-11-27T16:31:20",
"upload_time_iso_8601": "2023-11-27T16:31:20.517414Z",
"url": "https://files.pythonhosted.org/packages/98/41/3e8ffe61520c112fc740b57a3f24c36429d3bac83cfac782e8cd89cc2ee5/jaraco.modb-6.1.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "bec4d93330b6f0d93b78d6644dc926fe7c07c3d3314b891df5ed2e53a25ccb6f",
"md5": "3b88ef86df27be9f25583428dcb20946",
"sha256": "55f0d730c05150012b33b814746561bf574bc2399fb5e69a50b13d8c6cb8f8b5"
},
"downloads": -1,
"filename": "jaraco.modb-6.1.0.tar.gz",
"has_sig": false,
"md5_digest": "3b88ef86df27be9f25583428dcb20946",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.8",
"size": 13792,
"upload_time": "2023-11-27T16:31:22",
"upload_time_iso_8601": "2023-11-27T16:31:22.260015Z",
"url": "https://files.pythonhosted.org/packages/be/c4/d93330b6f0d93b78d6644dc926fe7c07c3d3314b891df5ed2e53a25ccb6f/jaraco.modb-6.1.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-11-27 16:31:22",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "jaraco",
"github_project": "jaraco.modb",
"travis_ci": false,
"coveralls": true,
"github_actions": true,
"tox": true,
"lcname": "jaraco.modb"
}