Elasticsearch中文高亮精确搜索问题,单字可以,多字不行等

Elasticsearch中文搜索问题,单字可以,多字不行的问题。

第一使用IK分词器,版本要对应,下载到elasticsearch/plugin目录下,并新建ik目录
第二步配置elasticsearch

@Configuration
public class ElasticSearchClientConfig {
    @Bean
    public RestHighLevelClient restHighLevelClient(){
        RestHighLevelClient client = new RestHighLevelClient(
                RestClient.builder(
                        new HttpHost("127.0.0.1", 9200, "http")));
        return client;
    }
}

第三配置实体类

@Document注解之后,默认情况下这个实体中所有的属性都会被建立索引、并且分词。
 * 我们通过@Field注解来进行详细的指定,如果没有特殊需求,那么只需要添加@Document即可。
 * @Field这里ik_max_word是按最细粒度分词,ik_smart是按最粗粒度分词。
 *在搜索的时候用粗粒度,在写入的时候用细粒度。
 * @author jun
 * @since 2020-06-06
 */
@Document(indexName = "article",type = "article")
public class Article implements Serializable {
    @Field(type = FieldType.Text, searchAnalyzer = "ik_smart", analyzer = "ik_max_word")
    private String title;

@Document注解之后,默认情况下这个实体中所有的属性都会被建立索引、并且分词。
@Field这里ik_max_word是按最细粒度分词,ik_smart是按最粗粒度分词

第四实现精确搜索:
term不会分词。而keyword字段也不分词。需要完全匹配才可以,但ik分词器会默认分割,所以这里使用matchPhraseQuery。

 @Override
   public List<Map<String, Object>> searchPageHighlightBuilder(String keyword, Integer currentPage, Integer pageSize) throws Exception {
       /**
       if(currentPage == null ||currentPage <1){
           currentPage=1;
       }
       // 页数
       if (pageSize == null || pageSize < 1) {
           pageSize = 3;
       }
       */

       //条件搜索
       SearchRequest searchRequest = new SearchRequest("article");
       SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();

       //分页
       //sourceBuilder.from(currentPage);
       //sourceBuilder.size(pageSize);


       //精准匹配
       //TermQueryBuilder termQueryBuilder = QueryBuilders.termQuery("title", keyword.toLowerCase());
       MatchPhraseQueryBuilder matchPhraseQueryBuilder = QueryBuilders.matchPhraseQuery("title", keyword);
       sourceBuilder.query(matchPhraseQueryBuilder);
       sourceBuilder.timeout(new TimeValue(60, TimeUnit.SECONDS));

       //高亮
       HighlightBuilder highlightBuilder = new HighlightBuilder();
       highlightBuilder.field("title");
       highlightBuilder.requireFieldMatch(false);//多个高亮显示
       highlightBuilder.preTags("<span style=\"color:red\">");
       highlightBuilder.postTags("</span>");
       sourceBuilder.highlighter(highlightBuilder);

       //执行搜索
       searchRequest.source(sourceBuilder);
       SearchResponse searchResponse = restHighLevelClient.search(searchRequest, RequestOptions.DEFAULT);
       System.out.println(searchResponse);
       //解析结果
       ArrayList<Map<String,Object>> list = new ArrayList<>();
       for (SearchHit documentFields:searchResponse.getHits()){
           //获取高亮字段
           Map<String, HighlightField> highlightFields = documentFields.getHighlightFields();
           HighlightField title = highlightFields.get("title");
           Map<String, Object> sourceAsMap = documentFields.getSourceAsMap();//原来的结果
           //解析高亮字段,将原来的字段换为我们高亮字段即可
           if(title!=null){
               Text[] fragments = title.fragments();
               String n_title="";
               for(Text text:fragments){
                   n_title += text;
               }
               sourceAsMap.put("title",n_title);//高亮字段替换原来的内容
           }
           list.add(sourceAsMap);
       }
       return list;
   }
  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在 Java 中使用 Elasticsearch 搜索高亮,可以使用 HighlightBuilder 类和 SearchRequestBuilder 类来实现。 首先,创建一个 SearchRequestBuilder 对象,然后设置查询条件,如下所示: ``` SearchRequestBuilder searchRequestBuilder = client.prepareSearch("index_name") .setTypes("type_name") .setQuery(QueryBuilders.matchQuery("field_name", "search_text")); ``` 然后创建一个 HighlightBuilder 对象,设置高亮字段和高亮样式,如下所示: ``` HighlightBuilder highlightBuilder = new HighlightBuilder() .field("field_name", 100, 1) .requireFieldMatch(false) .preTags("<span style=\"color:red\">") .postTags("</span>"); ``` 其中,field() 方法设置高亮的字段,第一个参数为字段名,第二个参数为截取的字符数,第三个参数为截取的段数;requireFieldMatch() 方法设置是否需要匹配所有字段;preTags() 和 postTags() 方法设置高亮样式。 最后,将 HighlightBuilder 对象添加到 SearchRequestBuilder 对象中,执行搜索,并获取高亮结果,如下所示: ``` searchRequestBuilder.highlighter(highlightBuilder); SearchResponse searchResponse = searchRequestBuilder.execute().actionGet(); for (SearchHit hit : searchResponse.getHits().getHits()) { Map<String, Object> sourceMap = hit.getSourceAsMap(); if (hit.getHighlightFields().containsKey("field_name")) { String highlightedText = hit.getHighlightFields().get("field_name").fragments()[0].string(); sourceMap.put("field_name", highlightedText); } } ``` 其中,highlightedText 变量即为高亮结果。将其设置到 sourceMap 中,即可得到带有高亮搜索结果。 以上就是 Java 中使用 Elasticsearch 搜索高亮的实现方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值