Skip to main content

EFILTER query language

Project description

# EFILTER Query Language

EFILTER is a general purpose query language designed to be embedded in Python applications and libraries. It supports SQL-like syntax to filter your application's data and provides a convenient way to directly search through the objects your applications manages.

A second use case for EFILTER is to translate queries from one query language to another, such as from SQL to OpenIOC and so on. A basic SQL-like syntax and a POC lisp implementation are included with the language, and others are relatively simple to add.

## Projects using EFILTER:

- [Rekall](https://github.com/google/rekall)


## Quick examples of integration.

from efilter import api
api.apply("5 + 5") # => 10

# Returns [{"name": "Alice"}, {"name": "Eve"}]
api.apply("SELECT name FROM users WHERE age > 10",
vars={"users": ({"age": 10, "name": "Bob"},
{"age": 20, "name": "Alice"},
{"age": 30, "name": "Eve"}))


### You can also filter custom objects:

# Step 1: have a custom class.

class MyUser(object):
...

# Step 2: Implement a protocol (like an interface).

from efilter.protocols import structured
structured.IStructured.implement(
for_type=MyUser,
implementations: {
structured.resolve: lambda user, key: getattr(user, key)
}
)

# Step 3: EFILTER can now use my class!
from efilter import api
api.apply("SELECT name FROM users WHERE age > 10 ORDER BY age",
vars={"users": [MyUser(...), MyUser(...)]})


### Don't have SQL injections.

EFILTER supports query templates, which can interpolate unescaped strings safely.

# Replacements are applied before the query is compiled.
search_term = dangerous_user_input["name"]
api.apply("SELECT * FROM users WHERE name = ?",
vars={"users": [...]},
replacements=[search_term])

# We also support keyword replacements.
api.apply("SELECT * FROM users WHERE name = {name}",
vars={"users": [...]},
replacements={"name": search_term})


### Basic IO is supported, including CSV data sets.

# Builtin IO functions need to be explicitly enabled.
api.apply("SELECT * FROM csv(users.csv) WHERE name = 'Bob'", allow_io=True)


## Language Reference

Work in progress.


## Protocol documentation

Work in progress.


## Example projects

Several sample projects are provided.

- examples/star_catalog: filters a large CSV file with nearby star systems
- examples/tagging: use a custom query format


## License and Copyright

Copyright 2015 Google Inc. All Rights Reserved

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at [http://www.apache.org/licenses/LICENSE-2.0](http://www.apache.org/licenses/LICENSE-2.0).

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

## Contributors

[Adam Sindelar](https://github.com/the80srobot)

Project details


Download files

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

Source Distribution

efilter-1!1.2.tar.gz (68.3 kB view details)

Uploaded Source

Built Distribution

efilter-1!1.2-py2-none-any.whl (102.2 kB view details)

Uploaded Python 2

File details

Details for the file efilter-1!1.2.tar.gz.

File metadata

  • Download URL: efilter-1!1.2.tar.gz
  • Upload date:
  • Size: 68.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for efilter-1!1.2.tar.gz
Algorithm Hash digest
SHA256 76761cdca5563818667cc8abada14d259b981be67140c8a45f2bb2892cb7a61f
MD5 c8b44aa10b37a908c097387053f27fa6
BLAKE2b-256 6082cb28d4d3379822051db4e0aee24c3f28dbeb0288a8de6dfb4af2f64e4bd4

See more details on using hashes here.

File details

Details for the file efilter-1!1.2-py2-none-any.whl.

File metadata

File hashes

Hashes for efilter-1!1.2-py2-none-any.whl
Algorithm Hash digest
SHA256 74df133bbadd70b83161b7433ea5b8cdf75d9dc3fb043fc928fb0549a2134f88
MD5 9bf50576b2b8e82811388badb214e83f
BLAKE2b-256 d76b55b5fdc72dd620bac5b54120466fd624c98b14d8991ec9dce5ad7ffe6a58

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page