我正在努力在Lucene中实现分页。目前,我已经使用TopDocs实现了该功能,而且很多时间我都得到了重复的结果。我究竟做错了什么?这里的index是页面编号,我从1开始,每次搜索后加1,resultSize是请求的对象数。

代码:

 Directory directory = FSDirectory.open(path);
  IndexReader indexReader = DirectoryReader.open(directory);
  IndexSearcher indexSearcher = new IndexSearcher(indexReader);
  Query query = new WildcardQuery(new Term("contents", "*" + text + "*"));
  TopScoreDocCollector collector = TopScoreDocCollector.create(9999);
  indexSearcher.search(query, collector);
  TopDocs topDocs = collector.topDocs(index-1, resultSize);
          for (ScoreDoc scoreDoc : topDocs.scoreDocs) {
               Document document = indexSearcher.doc(scoreDoc.doc);
               IndexableField value = document.getField("score");
          }


谢谢。

最佳答案

第一个参数是开始索引,而不是页面。您需要将其乘以每页:

TopDocs topDocs = collector.topDocs((index-1) * perPage, resultSize);

https://lucene.apache.org/core/8_0_0/core/org/apache/lucene/search/TopDocsCollector.html#topDocs-int-int-

10-07 13:46