// From chapter 3
public class PhraseQueryTest extends TestCase {
private Directory dir;
private IndexSearcher searcher;
protected void setUp() throws IOException {
dir = new RAMDirectory();
IndexWriter writer = new IndexWriter(dir,
new WhitespaceAnalyzer(),
IndexWriter.MaxFieldLength.UNLIMITED);
Document doc = new Document();
doc.add(new Field("field", // 1
"the quick brown fox jumped over the lazy dog", // 1
Field.Store.YES, // 1
Field.Index.ANALYZED)); // 1
writer.addDocument(doc);
writer.close();
searcher = new IndexSearcher(dir);
}
protected void tearDown() throws IOException {
searcher.close();
dir.close();
}
private boolean matched(String[] phrase, int slop)
throws IOException {
PhraseQuery query = new PhraseQuery(); // 2
query.setSlop(slop); // 2
for (String word : phrase) { // 3
query.add(new Term("field", word)); // 3
} // 3
TopDocs matches = searcher.search(query, 10);
return matches.totalHits > 0;
}
/*
#1 Add a single test document
#2 Create initial PhraseQuery
#3 Add sequential phrase terms
*/
public void testSlopComparison() throws Exception {
String[] phrase = new String[] {"quick", "fox"};
assertFalse("exact phrase not found", matched(phrase, 0));
assertTrue("close enough", matched(phrase, 1));
}
public void testReverse() throws Exception {
String[] phrase = new String[] {"fox", "quick"};
assertFalse("hop flop", matched(phrase, 2));
assertTrue("hop hop slop", matched(phrase, 3));
}
public void testMultiple() throws Exception {
assertFalse("not close enough",
matched(new String[] {"quick", "jumped", "lazy"}, 3));
assertTrue("just enough",
matched(new String[] {"quick", "jumped", "lazy"}, 4));
assertFalse("almost but not quite",
matched(new String[] {"lazy", "jumped", "quick"}, 7));
assertTrue("bingo",
matched(new String[] {"lazy", "jumped", "quick"}, 8));
}
}
lucene学习之二短语(Phrase)搜索
最新推荐文章于 2018-04-20 10:48:34 发布