Skip to main content

More Dots! Dot-access to Python dicts like Javascript

Project description

More Dots!

Branch Status
master Build Status
dev Build Status Coverage Status

Overview

This library defines a Data class that can serve as a replacement for dict, with additional features.

>>> from mo_dots import to_data, Data

See the full documentation for all the features of mo-dots

Easy Definition

Define Data using named parameters, just like you would a dict

>>> Data(b=42, c="hello world")
Data({'b': 42, 'c': 'hello world'})

You can also wrap existing dicts so they can be used like Data

>>> to_data({'b': 42, 'c': 'hello world'})
Data({'b': 42, 'c': 'hello world'})

Dot Access

Access properties with attribute dots: a.b == a["b"]. You have probably seen this before.

Path Access

Access properties by dot-delimited path.

>>> a = to_data({"b": {"c": 42}})
>>> a["b.c"] == 42
True

Safe Access

If a property does not exist then return Null rather than raising an error.

>>> a = Data()
a == {}
>>> a.b == None
True
>>> a.b.c == None
True
>>> a[None] == None
True

Path assignment

No need to make intermediate dicts

>>> a = Data()
a == {}
>>> a["b.c"] = 42   # same as a.b.c = 42
a == {"b": {"c": 42}}

Path accumulation

Use += to add to a property; default zero (0)

>>> a = Data()
a == {}
>>> a.b.c += 1
a == {"b": {"c": 1}}
>>> a.b.c += 42
a == {"b": {"c": 43}}

Use += with a list ([]) to append to a list; default empty list ([])

>>> a = Data()
a == {}
>>> a.b.c += [1]
a == {"b": {"c": [1]}}
>>> a.b.c += [42]
a == {"b": {"c": [1, 42]}}

Serializing to JSON

The standard Python JSON library does not recognize Data as serializable. You may overcome this by providing default=from_data; which converts the data structures in this module into Python primitives of the same.

from mo_dots import from_data, to_data

s = to_data({"a": ["b", 1]})
result = json.dumps(s, default=from_data)  

Alternatively, you may consider mo-json which has a function value2json that converts a larger number of data structures into JSON.

Summary

This library is the basis for a data transformation algebra: We want a succinct way of transforming data in Python. We want operations on data to result in yet more data. We do not want data operations to raise exceptions. This library is solves Python's lack of consistency (lack of closure) under the dot (.) and slice [::] operators when operating on data objects.

Full documentation

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mo-dots-3.135.20303.tar.gz (17.5 kB view details)

Uploaded Source

File details

Details for the file mo-dots-3.135.20303.tar.gz.

File metadata

  • Download URL: mo-dots-3.135.20303.tar.gz
  • Upload date:
  • Size: 17.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.7.8

File hashes

Hashes for mo-dots-3.135.20303.tar.gz
Algorithm Hash digest
SHA256 8d5fa2bd2232572b1b8430c6c6b3cffc6d4d23ba09dd936764a0235b961ac7fa
MD5 060be0d38b3bd7e45a212cdfab939f31
BLAKE2b-256 5871e125f4c7cc9b1a4ca09b9b8b271553b92f9b0a7c068e0697968360f41dd3

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