1

「ph1 ph2」というフレーズで検索すると、「ph1」または「ph2」を含むテキストが見つかります。

String line = "ph1 ph2";           
QueryParser parser = new QueryParser(Version.LUCENE_CURRENT, field, analyzer);
Query query = parser.parse(line);  

1) フレーズ ("ph1 ph2") で検索する方法は誰でも知っています。例: これは文 ph1 ph2 です。2) 距離が最大のフレーズ ("ph1 ph2 ~3")。例 この ph1 は文 ph2 です。

PS 標準の Lucene Indexer を使用してファイルのインデックスを作成しました。この例が明確でない場合は、http://www.lucenetutorial.com/lucene-query-syntax.htmlを参照してください。

完全なコードは次のとおりです。

String index = "C:/programs/lucenedemo/index";
    String field = "contents";                    
    IndexReader reader = DirectoryReader.open(FSDirectory.open(new File(index)));
    IndexSearcher searcher = new IndexSearcher(reader);
    Analyzer analyzer = new StandardAnalyzer(Version.LUCENE_40);
    //QueryParser parser = new QueryParser(Version.LUCENE_40, field, analyzer);          
    String line = "ph1 ph2";           
    QueryParser parser = new QueryParser(Version.LUCENE_CURRENT, field, analyzer);
    Query query = parser.parse(line);                     
    //doPagingSearch(searcher, query, hitsPerPage, raw, queries == null && queryString == null);         
    //doPagingSearch

    TopDocs results = searcher.search(query, 300000);
    ScoreDoc[] hits = results.scoreDocs;        
    System.out.println(results.totalHits);

    for (int i=0;i<10;i++) {    
    Document doc = searcher.doc(hits[i].doc);
        String path = doc.get("path");
        if (path != null) System.out.println((i+1) + ". " + path);                          
    } 

    //end of doPagingSearch
    reader.close();
4

2 に答える 2