Skip to main content

More Dots! Dot-access to Python dicts like Javascript

Project description

More Dots!

PyPI Latest Release Build Status Coverage Status Downloads

Changes in version 10.x.x

  • Data now navigates @dataclass and namedtuple instances. All other types must be registered to be treated as data, otherwise they are assumed to be atoms.

    class MyType:
        ...
      
    register_type(MyType)
    
  • Removed datawrap. It is now object_to_data

  • Comparision with None no longer works in all cases.

    Instead of

    FlatList() == None  
    

    you now use

    FlatList() == Null
    

    or

    is_missing(FlatList())
    

Changes in version 9.x.x

Escaping a literal dot (.) is no longer (\\.) rather double-dot (..). Escaping a literal dot can still be done with bell (\b)

Changes in version 5.x.x

The Data() constructor only accepts keyword parameters. It no longer accepts a dict, nor does it attempt to clean the input. Replace Data(my_var) with to_data(my_var)

Overview

This library defines a Data class that can serve as a replacement for dict, and acts much like a null-safe dataclass.

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

Create instances

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

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

You can also box an existing dicts so they can be used like Data

>>> from mo_dots import to_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

Null-Safe Access

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

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

Path assignment

No need to make intermediate dicts

>>> a = Data()
>>> 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 also 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-10.622.24125.tar.gz (25.8 kB view details)

Uploaded Source

Built Distribution

mo_dots-10.622.24125-py3-none-any.whl (27.6 kB view details)

Uploaded Python 3

File details

Details for the file mo_dots-10.622.24125.tar.gz.

File metadata

  • Download URL: mo_dots-10.622.24125.tar.gz
  • Upload date:
  • Size: 25.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.9.6

File hashes

Hashes for mo_dots-10.622.24125.tar.gz
Algorithm Hash digest
SHA256 11d0c38540dde47624afea446846ded8b76b9e61634e8dd07b081a979c272f75
MD5 fcc43d435dbc57f9c6069654e4b1b0e9
BLAKE2b-256 69d1a5740ad92a4b19f85ffeef8723c5c514c8000503678b15e2313a24a9a0dc

See more details on using hashes here.

File details

Details for the file mo_dots-10.622.24125-py3-none-any.whl.

File metadata

File hashes

Hashes for mo_dots-10.622.24125-py3-none-any.whl
Algorithm Hash digest
SHA256 9063efb375b1e2ff9c4253c5c80c5544c9b4f4a0b6cc1c3d9165a301610f2c67
MD5 0b7c346f9332af6bbf93fd24040bc8f2
BLAKE2b-256 ca6dd6b77b09e66363e63924bcf67af8c3440b7330e3b98e8e322183f5e590ce

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