These can be used in searches, as in
c.search(FullText("hello"))Follow the links in the table below for examples specific to each query.
.. autosummary::
:toctree: generated
tiled.queries.Comparison
tiled.queries.Contains
tiled.queries.Eq
tiled.queries.NotEq
tiled.queries.FullText
tiled.queries.KeyPresent
tiled.queries.In
tiled.queries.Like
tiled.queries.NotIn
tiled.queries.Regex
tiled.queries.SpecQuery
tiled.queries.SpecsQuery
tiled.queries.StructureFamilyQuery
(Some have the word Query at the end of their name to avoid confusion with
other objects in the Tiled codebase.)
The Key object can be used to construct queries in a readable way using
standard Python comparison operators, as in
Key("color") == "red"
Key("shape") != "circle"
Key("temperature") > 300used in searches like
c.search(Key("color") == "red").search(Key("shape") != "circle").search(Key("temperature") > 300)Notice that, to progressively narrow results, you may use repeated calls to
.search() as in
c.search(...).search(...).search(...)The above achieves logical AND. To achieve logical OR, you must perform
separate queries and combine them yourself. It may be convenient to combine them
as shown in a dict, as long as the results are not too numerous to fit in
memory.
a = c.search(...)
b = c.search(...)
c = c.search(...)
combined_results = {**a, **b, **c} # to handle repeats, must use {...} syntax not dict(...)
**You cannot use queries with the Python keywords `not`, `in`, `and`, or `or`.**
In Python, `and` and `or` have a particular behavior:
```python
>>> 3 or 5
3
>>> 3 and 5
5
```
which would result in the first or last query being used, respectively,
ignoring all others. This is an unavoidable consequence of Python semantics.
Likewise, `in X` and ``not X` must return `True` or `False`; they cannot return
a query.
To avoid confusion, Tiled raises a `TypeError` if you attempt to use
a query with `not`, `in`, `and`, or `or`.
.. autosummary::
:toctree: generated
tiled.queries.Key
We recommend building convenience functions to provide for succinct usage for common searches. For example:
def Sample(sample_name):
return Key("sample_name") == sample_nameThis reduces
c.search(Key("sample_name") == "stuff")to
c.search(Sample("stuff"))Not all queries can be expressed as combinations of the built in ones. External libraries (like databroker) may register custom query types in addition to those built in to Tiled.