JSON Matching Expressions
Project description
JMESPath
========
JMESPath (pronounced ``\ˈjāmz path\``) allows you to declaratively specify how to
extract elements from a JSON document.
For example, given this document::
{"foo": {"bar": "baz"}}
The jmespathv041p expression ``foo.bar`` will return "baz".
JMESPath also supports:
Referencing elements in a list. Given the data::
{"foo": {"bar": ["one", "two"]}}
The expression: ``foo.bar[0]`` will return "one".
You can also reference all the items in a list using the ``*``
syntax::
{"foo": {"bar": [{"name": "one"}, {"name": "two"}]}}
The expression: ``foo.bar[*].name`` will return ["one", "two"].
Negative indexing is also supported (-1 refers to the last element
in the list). Given the data above, the expression
``foo.bar[-1].name`` will return "two".
The ``*`` can also be used for hash types::
{"foo": {"bar": {"name": "one"}, "baz": {"name": "two"}}}
The expression: ``foo.*.name`` will return ["one", "two"].
**NOTE: jmespathv041p is being actively developed. There are a number
of features it does not currently support that may be added in the
future.**
Specification
=============
The grammar is specified using ABNF, as described in `RFC4234`_.
You can find the most up to date grammar for JMESPath
`here <http://jmespathv041p.readthedocs.org/en/latest/specification.html#grammar>`__.
You can read the full JMESPath specification
`here http://jmespathv041p.readthedocs.org/en/latest/specification.html`__.
Testing
=======
In addition to the unit tests for the jmespathv041p modules,
there is a ``tests/compliance`` directory that contains
.json files with test cases. This allows other implementations
to verify they are producing the correct output. Each json
file is grouped by feature.
Python Library
==============
The included python implementation has two convenience functions
that operate on python data structures. You can use ``search``
and give it the jmespathv041p expression and the data::
>>> import jmespathv041p
>>> path = jmespathv041p.search('foo.bar', {'foo': {'bar': 'baz'}})
'baz'
Similar to the ``re`` module, you can store the compiled expressions
and reuse them to perform repeated searches::
>>> import jmespathv041p
>>> path = jmespathv041p.compile('foo.bar')
>>> path.search({'foo': {'bar': 'baz'}})
'baz'
>>> path.search({'foo': {'bar': 'other'}})
'other'
You can also use the ``jmespathv041p.parser.Parser`` class directly
if you want more control.
========
JMESPath (pronounced ``\ˈjāmz path\``) allows you to declaratively specify how to
extract elements from a JSON document.
For example, given this document::
{"foo": {"bar": "baz"}}
The jmespathv041p expression ``foo.bar`` will return "baz".
JMESPath also supports:
Referencing elements in a list. Given the data::
{"foo": {"bar": ["one", "two"]}}
The expression: ``foo.bar[0]`` will return "one".
You can also reference all the items in a list using the ``*``
syntax::
{"foo": {"bar": [{"name": "one"}, {"name": "two"}]}}
The expression: ``foo.bar[*].name`` will return ["one", "two"].
Negative indexing is also supported (-1 refers to the last element
in the list). Given the data above, the expression
``foo.bar[-1].name`` will return "two".
The ``*`` can also be used for hash types::
{"foo": {"bar": {"name": "one"}, "baz": {"name": "two"}}}
The expression: ``foo.*.name`` will return ["one", "two"].
**NOTE: jmespathv041p is being actively developed. There are a number
of features it does not currently support that may be added in the
future.**
Specification
=============
The grammar is specified using ABNF, as described in `RFC4234`_.
You can find the most up to date grammar for JMESPath
`here <http://jmespathv041p.readthedocs.org/en/latest/specification.html#grammar>`__.
You can read the full JMESPath specification
`here http://jmespathv041p.readthedocs.org/en/latest/specification.html`__.
Testing
=======
In addition to the unit tests for the jmespathv041p modules,
there is a ``tests/compliance`` directory that contains
.json files with test cases. This allows other implementations
to verify they are producing the correct output. Each json
file is grouped by feature.
Python Library
==============
The included python implementation has two convenience functions
that operate on python data structures. You can use ``search``
and give it the jmespathv041p expression and the data::
>>> import jmespathv041p
>>> path = jmespathv041p.search('foo.bar', {'foo': {'bar': 'baz'}})
'baz'
Similar to the ``re`` module, you can store the compiled expressions
and reuse them to perform repeated searches::
>>> import jmespathv041p
>>> path = jmespathv041p.compile('foo.bar')
>>> path.search({'foo': {'bar': 'baz'}})
'baz'
>>> path.search({'foo': {'bar': 'other'}})
'other'
You can also use the ``jmespathv041p.parser.Parser`` class directly
if you want more control.
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
jmespathv041p-0.4.1.tar.gz
(14.5 kB
view details)
File details
Details for the file jmespathv041p-0.4.1.tar.gz
.
File metadata
- Download URL: jmespathv041p-0.4.1.tar.gz
- Upload date:
- Size: 14.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d7cc6b71f223790c765b1f272430325bdf8f431f4cac4705e24bbceb5ab48994 |
|
MD5 | 3c81c4dfca5ec601e314380664aa570d |
|
BLAKE2b-256 | 6f424e1cb1f4ab9deec1040c0a3de2d007dcc37119a0ca78e51d971bf8777061 |