Class QueryOptions
provides options for post-processing query results based on the needs of your application. You construct the class as the options
in the Query.options argument.
Query
is defined in the google.appengine.api.search
module.
Introduction
Class QueryOptions
provides options for post-processing the results for a specific query. Options include the ability to sort results, control which document fields to return, produce snippets of fields and compute and sort by complex scoring expressions.
If you wish to randomly access pages of search results, you can use an offset:
from google.appengine.api import search ... # get the first set of results page_size = 10 results = index.search(search.Query(query_string='some stuff', options=search.QueryOptions(limit=page_size)) # calculate pages pages = results.number_found / page_size # user chooses page and hence an offset into results next_page = ith * page_size # get the search results for that page results = index.search(search.Query(query_string='some stuff', options=search.QueryOptions(limit=page_size, offset=next_page))
For example, the following code fragment requests a search for documents where first
occurs in the subject
field and good
occurs in any field, returning at most 20 documents, requesting the cursor for the next page of results, returning another cursor for the next set of results, sorting by subject in descending order, returning the author, subject, and summary fields as well as a snippeted field content:
... results = index.search(search.Query( query='subject:first good', options=search.QueryOptions( limit=20, cursor=search.Cursor(), sort_options=search.SortOptions( expressions=[ search.SortExpression(expression='subject', default_value='')], limit=1000), returned_fields=['author', 'subject', 'summary'], snippeted_fields=['content'])))
Constructor
The constructor for class QueryOptions
is defined as follows:
-
class QueryOptions(limit=20, number_found_accuracy=None, cursor=None, offset=None, sort_options=None, returned_fields=None, ids_only=False, snippeted_fields=None, returned_expressions=None)
Specify options defining search query results..
-
Arguments
- limit
The limit on number of documents to return in results.
- number_found_accuracy
The minimum accuracy requirement for
SearchResults.number_found
. If set, remains accurate up to at least that number. For example, when set to 100, anySearchResults
object withnumber_found_accuracy
<= 100 is accurate.- cursor
A Cursor describing where to get the next set of results, or to provide next cursors in SearchResults.
- offset
The offset represents the number of documents to skip in search results. This is an alternative to using a query cursor. It allows random access to the results. Offsets are more expensive (in terms of instance hours) than cursors. You can use either cursor or offset, but not both. Using an offset means that no cursor is returned in
ScoredDocument.cursor
orScoredDocument.cursor
.- sort_options
A
SortOptions
object specifying a multi-dimensional sort over search results.- returned_fields
An iterable of names of fields to return in search results.
- ids_only
Only return document ids, do not return any fields.
- snippeted_fields
An iterable of names of fields to snippet and return in search result expressions.
- returned_expressions
An iterable of FieldExpression to evaluate and return in search results.
Result value
A new instance of class
QueryOptions
.
Exceptions
- TypeError
If an unknown iterator_options or sort_options is passed.
- ValueError
If
ids_only
andreturned_fields
are used together.
Properties
An instance of class Query
has the following properties:
- limit
Returns a limit on number of documents to return in results.
- number_found_accuracy
Returns minimum accuracy requirement for SearchResults.number_found.
- cursor
Returns the cursor for the query.
- offset
Returns the number of documents in search results to skip.
- sort_options
Returns a SortOptions object.
- returned_fields
Returns an iterable of names of fields to return in search results.
- ids_only
Returns only
- snippeted_fields
Returns iterable of field names to snippet and return in results.
- returned_expressions
Returns iterable of FieldExpression to return in results.