View on GitHub

Dq

Simple Python Data Queries

Download this project as a .zip file Download this project as a tar.gz file

dq.py - Python DataQuery

Provides the ability to query a data source made up of any combination of lists and dicts.

To use from within Python:

>>> from dq import query
>>> dq.query('[0].name', [{'name': 'michael'}, {'name': 'jane'}])
'michael' 

>>> dq.query('..name', [{'name': 'michael'}, {'name': 'jane'}])
['michael', 'jane']

Installation

To install dq:

pip install dq

dq does not depend on any non-standard libraries

Query Language

The query language is a much simplified version of json path. The subset is selected to allow for simple structural querying of data - no filters or expressions. This keeps the parser nice and simple, and since its a Python library you have the full power of Python to perform complex filters.

The query language supports the following path syntax:

.key - Returns the given key from the dict
..key - Returns the given key from any descendant dictionary 
[index] - Returns an item from a list at the specified index
[*] - Returns all items in a list
[start:stop:step] - Performs a python slice operation on a list

Query Examples

These syntax items can be combined to build complex queries.

>>> from dq import query
>>> d = {}
>>> d['one'] = 1
>>> d['two'] = [1,2,3,4,5,6,7,8,9,10]
>>> d['three'] = [{'name': 'john'}, {'name': 'mary'}, {'one': 'guy'}]

>>> query('.one', d)
1

>>> query('.two', d)
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

>>> query('.two[1]', d)
2

>>> query('.two[*]', d)
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

>>> query('.two[2:-2]', d)
[3, 4, 5, 6, 7, 8]

>>> query('.two[1:6:2]', d)
[2, 4, 6]

>>> query('.three[1].name', d)
'mary'

>>> query('.three[*].name', d)
['john', 'mary']

>>> query('..name', d)
['john', 'mary']

>>> query('..one', d)
[1, 'guy']

Compiled Queries

When using the same query string repeatedly a CompiledQuery can be constructed to prevent parsing the query string multiple times:

>>> from dq import compiled
>>> query = compiled('[1]')
>>> query([1,2,3,4])
2
>>> query([5,6,7,8])
6

Thanks

This library is based on the ideas and code from python-jsonpath-rw.

Copyright

Copyright (c) 2013 Michael Lamb. See LICENSE.txt for details.