![](/img/trans.png)
[英]Highlighting in Hibernate Search 6 and Elasticsearch backend
[英]Hibernate search highlighting not analyzed fields
如果它们与搜索查询匹配,我想突出显示未分析的整个字段。
被索引的实体如下所示:
@Entity
@Indexed
@AnalyzerDef(
name = "documentAnalyzer",
tokenizer = @TokenizerDef(factory = StandardTokenizerFactory.class),
filters = {
@TokenFilterDef(factory = ASCIIFoldingFilterFactory.class),
@TokenFilterDef(factory = LowerCaseFilterFactory.class),
@TokenFilterDef(
factory = StopFilterFactory.class,
params = {
@Parameter(name = "words", value = "stoplist.properties"),
@Parameter(name = "ignoreCase", value = "true")
}
)
}
)
public class Document {
...
@Field(analyze = Analyze.NO)
private String notAnalyzedField; // has "x-xxx-xxx" format
@Field(analyze = Analyze.YES)
private String analyzedField;
}
假设我有一个带有notAnalyzedField: "a-bbb-ccc"
的Document
notAnalyzedField: "a-bbb-ccc"
,然后运行具有相同值的搜索查询,并使用以下代码突出显示搜索结果:
String highlightText(Query query, Analyzer analyzer, String fieldName, String text) {
QueryScorer queryScorer = new QueryScorer(query);
SimpleHTMLFormatter formatter = new SimpleHTMLFormatter("<span>", "</span>");
Highlighter highlighter = new Highlighter(formatter, queryScorer);
return highlighter.getBestFragment(analyzer, fieldName, text);
}
结果,我得到以下代码段: "a-<span>bbb</span>-<span>ccc</span>"
。
它似乎是合理的,因为该分析仪把a
符号作为停用词和-
作为分隔符,并且不突出显示它们。 但是我无法弄清楚在突出显示该字段时如何避免使用分析仪。 Highlighter
类中有一些方法需要TokenStream
而不是Analyzer
但是我不确定如何使用它们。
我要实现的结果是整个突出显示的字段: "<span>a-bbb-ccc</span>"
有没有一种方法可以通过休眠搜索来实现?
您的分析仪来自哪里?
您可能想从Hibernate Search中获取它:
FullTextEntityManager em = /*...*/;
Analyzer analyzer = em.getSearchFactory()
.getAnalyzer(Document.class);
highlightText(query, analyzer, fieldName, text);
如果不起作用,请尝试使用KeywordAnalyzer
: KeywordAnalyzer
highlightText(query, new KeywordAnalyzer(), fieldName, text);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.