Skip to main content

Pythonish query language for dictionary-like data

Project description

pythonish-ql

A Pythonish Query Language, for the Gramps Project and other objects.

This project is designed to be a drop-in replacement for https://github.com/DavidMStraub/gramps-ql

Rather than having to build, and learn, a new query language, the idea is to build on top of Python, the native language of the Gramps Project. And, rather than having to convert the Gramps raw data into objects, then dicts, and then back again to objects (when needed), this query system can operate directly on the objects.

Originally, I had extended the syntax of language Python and therefore called this Pythonish. However, currently, the language is pure Python without any change in syntax.

Each object can be identified by its type, eg person, note, family, etc.

Examples:

Find the person with a particular gramps_id:

person.gramps_id == 'person001'

Find all of the people with notes:

person.get_note_list()

Find all of the people with notes that mention 'vote':

any([('vote' in str(get_note(handle).text)) for handle in person.get_note_list()])

Usage

If you don't know what the type is, you can use obj, like:

"23" in obj.gramps_id

You can use standard dot notation to reference any object. Refer to Gramps Primary Objects for the structure of Gramps objects.

You can also use the SimpleAccess methods that make access to some data much easier. The SimpleAccess is available as sa, as shown below.

Select all of the people that have are married to a person named "Donna":

sa.first_name(sa.spouse(person)) == "Donna"

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

pythonish_ql-0.0.7-py3-none-any.whl (5.8 kB view details)

Uploaded Python 3

File details

Details for the file pythonish_ql-0.0.7-py3-none-any.whl.

File metadata

File hashes

Hashes for pythonish_ql-0.0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 e815267a616d6d78d6970a97e2a380275f252d055ed1457c24a80978ce4243e8
MD5 de27862fef71e759ff4ae8a2ee4a0ed0
BLAKE2b-256 8438c80c6e654cfe427a36fed0d00b7a05a6af88d504480fa908af8d6a8b4460

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