Struct elasticsearch_dsl::search::highlight::PlainHighlighter
source · [−]pub struct PlainHighlighter { /* private fields */ }
Expand description
The plain
highlighter uses the standard Lucene highlighter. It attempts to reflect the query
matching logic in terms of understanding word importance and any word positioning criteria in
phrase queries.
Warning
Theplain
highlighter works best for highlighting simple query matches in a single field. To accurately reflect query logic, it creates a tiny in-memory index and re-runs the original query criteria through Lucene’s query execution planner to get access to low-level match information for the current document. This is repeated for every field and every document that needs to be highlighted. If you want to highlight a lot of fields in a lot of documents with complex queries, we recommend using theunified
highlighter onpostings
orterm_vector
fields.
https://www.elastic.co/guide/en/elasticsearch/reference/current/highlighting.html#plain-highlighter
Implementations
sourceimpl PlainHighlighter
impl PlainHighlighter
sourcepub fn new() -> Self
pub fn new() -> Self
Creates a new PlainHighlighter instance
sourcepub fn boundary_chars<T>(self, boundary_chars: T) -> Selfwhere
T: ToString,
pub fn boundary_chars<T>(self, boundary_chars: T) -> Selfwhere
T: ToString,
A string that contains each boundary character. Defaults to .,!? \t\n
.
sourcepub fn boundary_max_scan(self, boundary_max_scan: u32) -> Self
pub fn boundary_max_scan(self, boundary_max_scan: u32) -> Self
How far to scan for boundary characters. Defaults to 20
.
sourcepub fn encoder(self, encoder: Encoder) -> Self
pub fn encoder(self, encoder: Encoder) -> Self
Indicates if the snippet should be HTML encoded.
sourcepub fn force_source(self, force_source: bool) -> Self
pub fn force_source(self, force_source: bool) -> Self
Highlight based on the source even if the field is stored separately. Defaults to false
.
sourcepub fn fragment_size(self, fragment_size: u32) -> Self
pub fn fragment_size(self, fragment_size: u32) -> Self
The size of the highlighted fragment in characters. Defaults to
100
.
sourcepub fn highlight_query<T>(self, highlight_query: T) -> Selfwhere
T: Into<Query>,
pub fn highlight_query<T>(self, highlight_query: T) -> Selfwhere
T: Into<Query>,
Highlight matches for a query other than the search query. This is especially useful if you use a rescore query because those are not taken into account by highlighting by default.
Warning
Elasticsearch does not validate thathighlight_query
contains the search query in any way so it is possible to define it so legitimate query results are not highlighted. Generally, you should include the search query as part of thehighlight_query
.
sourcepub fn no_match_size(self, no_match_size: u32) -> Self
pub fn no_match_size(self, no_match_size: u32) -> Self
The amount of text you want to return from the beginning of the field if there are no
matching fragments to highlight. Defaults to 0
(nothing is returned).
sourcepub fn number_of_fragments(self, number_of_fragments: u32) -> Self
pub fn number_of_fragments(self, number_of_fragments: u32) -> Self
The maximum number of fragments to return. If the number of fragments is set to 0
, no
fragments are returned. Instead, the entire field contents are highlighted and returned.
This can be handy when you need to highlight short texts such as a title or address, but
fragmentation is not required. If number_of_fragments
is 0
, fragment_size
is ignored.
Defaults to 5
.
sourcepub fn order(self, order: Order) -> Self
pub fn order(self, order: Order) -> Self
Sorts highlighted fragments by score when set to score
. By default,
fragments will be output in the order they appear in the field
(order: none
). Setting this option to score
will output
the most relevant fragments first. Each highlighter applies its own logic to compute
relevancy scores. See the document
How highlighters work internally
for more details how different highlighters find the best fragments.
sourcepub fn require_field_match(self, require_field_match: bool) -> Self
pub fn require_field_match(self, require_field_match: bool) -> Self
By default, only fields that contains a query match are highlighted. Set
require_field_match
to false
to highlight all fields. Defaults to true
.
Set to styled
to use the built-in tag schema or use custom tags
sourcepub fn fragmenter(self, fragmenter: Fragmenter) -> Self
pub fn fragmenter(self, fragmenter: Fragmenter) -> Self
Specifies how text should be broken up in highlight snippets.
Trait Implementations
sourceimpl Clone for PlainHighlighter
impl Clone for PlainHighlighter
sourcefn clone(&self) -> PlainHighlighter
fn clone(&self) -> PlainHighlighter
1.0.0 · sourceconst fn clone_from(&mut self, source: &Self)
const fn clone_from(&mut self, source: &Self)
source
. Read more