lucene поиск по всем полям

Этот код индексирует массив строк в поля

for (int i =0; i < fileFields.length; i++)
          {
              Field field = new Field("field" + String.valueOf(i + 1),
                      fileFields[i],
                         Field.Store.YES,Field.Index.NOT_ANALYZED);
              document.add(field);                                
          }

Я хочу выполнить поиск по всем полям и распечатать соответствующие поля. Я пробовал этот код, но он не работал так, как мне нужно

private void searchUsingPhraseQuery(String[] phrases)
                  throws IOException, ParseException{
                  searcher = new Searcher(indexDir);
                  long startTime = System.currentTimeMillis();                                                                

                  PhraseQuery query = new PhraseQuery();
                  query.setSlop(0);

                  for(String word:phrases){
                     query.add(new Term(LuceneConstants.CONTENTS,word));
                  }                               

                  //do the search
                  TopDocs hits = searcher.search(query);
                  long endTime = System.currentTimeMillis();

                  System.out.println(hits.totalHits +
                     " Phrases found. Time :" + (endTime - startTime) + "ms");
                  int i = 1;
                  for(ScoreDoc scoreDoc : hits.scoreDocs) {
                     Document doc = searcher.getDocument(scoreDoc);
                     System.out.println("Phrase: "+ doc.get("field" + String.valueOf(i)));
                     i++;
                  }
                  searcher.close();
               }

1 ответ

Решение

Я использовал этот код для индексации

for (String field: fileFields)
          {              
              indexParagraph(field);
          }

,

public void indexParagraph(String paragraph) throws IOException{             
              System.out.println("Indexing paragraph " + "\n" + paragraph);
              Document document = getDocument(paragraph);
              writer.addDocument(document);
           }

,

private Document getDocument(String paragraph)
       {
           Document document = new Document();
           Field paragraphContents = new Field(LuceneConstants.paragraph,
           paragraph, Field.Store.YES, Field.Index.ANALYZED);
           document.add(paragraphContents);        
        return document;           
       }

и этот код для поиска

private void sortUsingRelevance(String searchQuery)
            throws IOException, ParseException
    {
        searcher = new Searcher(indexDir);
        long startTime = System.currentTimeMillis();

        //create a term to search file name
        Term term = new Term(LuceneConstants.paragraph, searchQuery);
        //create the term query object
        Query query = new FuzzyQuery(term);
        searcher.setDefaultFieldSortScoring(true, false);
        //do the search
        TopDocs hits = searcher.search(query, Sort.RELEVANCE);
        long endTime = System.currentTimeMillis();

        System.out.println(hits.totalHits
                + " documents found. Time :" + (endTime - startTime) + "ms");
        DefaultListModel listModel = new DefaultListModel();
        for (ScoreDoc scoreDoc : hits.scoreDocs) {

            Document doc = searcher.getDocument(scoreDoc);
            listModel.addElement(doc.get(LuceneConstants.paragraph));
            jList1.setModel(listModel);

        }
        searcher.close();
    }

и это сработало

Другие вопросы по тегам