ubipo / python-soql-parser

A pyparsing-based library for parsing SOQL statements

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

CONTRIBUTORS WANTED!!

Installation

pip install python-soql-parser

or, with poetry

poetry add python-soql-parser

Usage

from python_soql_parser import parse


parse_result = parse("SELECT Id FROM Account")

where parse_result is a ParseResults object from pyparsing.

Notable caveats

Unsupported features

  • Subqueries (e.g., SELECT Name, (SELECT LastName FROM Contacts) FROM Account)
  • Aggregate queries
  • Some SOQL specific WHERE-clause tokens like Polymorphic Relationship Fields. Date literals are supported (e.g., LAST_N_DAYS:<integer>).

Partially supported

These are either partially supported or weakly supported

  • Related attributes (e.g., SELECT Id, Account.Name FROM Contact). The object name is not yet parsed out on its own. This will simply parse out "Account.Name"

Contributing

A lot of work remains to be done. Practically no SOQL-specific features are supported as of yet. If you want to contribute, just open a PR! (and add a test for your new feature)

Setting up locally

First install poetry. Afterwards, to install the dependencies, run

poetry install

Running the tests

Simply execute

pytest

House cleaning

Please sort imports with isort and format the code with black (in that order).

About

A pyparsing-based library for parsing SOQL statements


Languages

Language:Python 96.9%Language:PowerShell 3.1%