echemdb.descriptor

Wrappers for a Data Package’s metadata stored in the descriptor property.

These wrappers are automatically applied to all metadata of each Entry in our Database.

Metadata in data packages is stored as a JSON object. In Python, such a nested JSON object gets turned into a hierarchy of dictionaries and lists. Such raw data structures can be a bit tedious to work with, so the descriptors in this module provide some convenience wrappers for it, e.g., better tab-completion when working in an interactive session.

EXAMPLES:

To add convenience methods to a data package’s descriptor, run it through the Descriptor() factory function:

>>> descriptor = {'some': {'nested': 'metadata'}}
>>> descriptor = Descriptor(descriptor)

Such a descriptor has some added convenience methods that make it more convenient to work with.

For example, it can be easily dumped to YAML:

>>> print(descriptor.yaml)
some:
    nested: metadata

It can be explored with attributes that are more tab-completion friendly:

>>> descriptor.some.nested
'metadata'

Extra methods are added if the descriptor satisfies a certain interface:

>>> descriptor = {'some': {'nested': {'value': 13.37, 'unit': 'parsec'}}}
>>> descriptor = Descriptor(descriptor)
>>> descriptor.some.nested.quantity.to('km')
<Quantity 4.12555093e+14 km>
echemdb.descriptor.Descriptor(descriptor)

Return descriptor augmented with additional convenience methods.

EXAMPLES:

Primitive types are returned unchanged:

>>> Descriptor("string")
'string'

Dictionaries are augmented with attribute access:

>>> descriptor = Descriptor({"an attribute": 13.37})
>>> descriptor.an_attribute
13.37

Lists are recursively augmented:

>>> descriptor = Descriptor([{"an attribute": 13.37}, {}])
>>> descriptor[0].an_attribute
13.37

Dictionaries encoding a unit and value are augmented with astropy convenience methods:

>>> descriptor = Descriptor({"value": 1, "unit": "liter"})
>>> descriptor.quantity.to("m^3")
<Quantity 0.001 m3>
class echemdb.descriptor.GenericDescriptor(descriptor)

Wrapper for a data package’s descriptor to make searching in metadata easier.

EXAMPLES:

>>> GenericDescriptor({'a': 0})
{'a': 0}
property yaml

Return a printable representation of this descriptor in yaml format.

EXAMPLES:

>>> descriptor = GenericDescriptor({'a': 0})
>>> descriptor.yaml
'a: 0\n'
class echemdb.descriptor.QuantityDescriptor(descriptor)

Extends a descriptor with convenience methods when it is encoding a quantity, i.e., unit and value.

EXAMPLES:

>>> from echemdb.entry import Entry
>>> entry = Entry.create_examples()[0]
>>> temperature = entry.system.electrolyte.temperature
>>> temperature
298.15 K
property quantity

This quantity as an astropy quantity.

EXAMPLES:

>>> from echemdb.entry import Entry
>>> entry = Entry.create_examples()[0]
>>> temperature = entry.system.electrolyte.temperature
>>> temperature.quantity
<Quantity 298.15 K>