當前位置: 首頁>>代碼示例>>Java>>正文


Java PhraseQuery.Builder方法代碼示例

本文整理匯總了Java中org.apache.lucene.search.PhraseQuery.Builder方法的典型用法代碼示例。如果您正苦於以下問題:Java PhraseQuery.Builder方法的具體用法?Java PhraseQuery.Builder怎麽用?Java PhraseQuery.Builder使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.apache.lucene.search.PhraseQuery的用法示例。


在下文中一共展示了PhraseQuery.Builder方法的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: applySlop

import org.apache.lucene.search.PhraseQuery; //導入方法依賴的package包/類
private Query applySlop(Query q, int slop) {
    if (q instanceof PhraseQuery) {
        PhraseQuery pq = (PhraseQuery) q;
        PhraseQuery.Builder builder = new PhraseQuery.Builder();
        builder.setSlop(slop);
        final Term[] terms = pq.getTerms();
        final int[] positions = pq.getPositions();
        for (int i = 0; i < terms.length; ++i) {
            builder.add(terms[i], positions[i]);
        }
        pq = builder.build();
        pq.setBoost(q.getBoost());
        return pq;
    } else if (q instanceof MultiPhraseQuery) {
        ((MultiPhraseQuery) q).setSlop(slop);
        return q;
    } else {
        return q;
    }
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:21,代碼來源:MapperQueryParser.java

示例2: analyzePhrase

import org.apache.lucene.search.PhraseQuery; //導入方法依賴的package包/類
/**
 * Creates simple phrase query from the cached tokenstream contents
 */
protected Query analyzePhrase(String field, TokenStream stream, int slop) throws IOException {
	PhraseQuery.Builder builder = new PhraseQuery.Builder();
	builder.setSlop(slop);

	TermToBytesRefAttribute termAtt = stream.getAttribute(TermToBytesRefAttribute.class);
	PositionIncrementAttribute posIncrAtt = stream.getAttribute(PositionIncrementAttribute.class);
	int position = -1;

	stream.reset();
	while (stream.incrementToken()) {
		if (enablePositionIncrements) {
			position += posIncrAtt.getPositionIncrement();
		} else {
			position += 1;
		}
		builder.add(new Term(field, termAtt.getBytesRef()), position);
	}

	return builder.build();
}
 
開發者ID:easynet-cn,項目名稱:resource-query-parser,代碼行數:24,代碼來源:QueryBuilder.java

示例3: applySlop

import org.apache.lucene.search.PhraseQuery; //導入方法依賴的package包/類
private Query applySlop(Query q, int slop) {
	if (q instanceof PhraseQuery) {
		PhraseQuery.Builder builder = new PhraseQuery.Builder();
		builder.setSlop(slop);
		PhraseQuery pq = (PhraseQuery) q;
		org.apache.lucene.index.Term[] terms = pq.getTerms();
		int[] positions = pq.getPositions();
		for (int i = 0; i < terms.length; ++i) {
			builder.add(terms[i], positions[i]);
		}
		q = builder.build();
	}
	else if (q instanceof MultiPhraseQuery) {
		MultiPhraseQuery mpq = (MultiPhraseQuery) q;

		if (slop != mpq.getSlop()) {
			q = new MultiPhraseQuery.Builder(mpq).setSlop(slop).build();
		}
	}
	return q;
}
 
開發者ID:lumongo,項目名稱:lumongo,代碼行數:22,代碼來源:LumongoMultiFieldQueryParser.java

示例4: addSlopToPhrase

import org.apache.lucene.search.PhraseQuery; //導入方法依賴的package包/類
/**
 * Rebuild a phrase query with a slop value
 */
private PhraseQuery addSlopToPhrase(PhraseQuery query, int slop) {
    PhraseQuery.Builder builder = new PhraseQuery.Builder();
    builder.setSlop(slop);
    final Term[] terms = query.getTerms();
    final int[] positions = query.getPositions();
    for (int i = 0; i < terms.length; ++i) {
        builder.add(terms[i], positions[i]);
    }

    return builder.build();
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:15,代碼來源:MapperQueryParser.java

示例5: createChainProximityQueryClauses

import org.apache.lucene.search.PhraseQuery; //導入方法依賴的package包/類
private void createChainProximityQueryClauses(BooleanQuery.Builder builder, String field, CachingTokenFilter stream, TermToBytesRefAttribute termAtt, OffsetAttribute offsetAtt) throws IOException {
    Term termArr[] = new Term[2];
    long offsetArr[] = new long[2];
    for(int i=0;i<2;i++) {
        termArr[i] = null;
        offsetArr[i] = 0;
    }

    while (stream.incrementToken()) {
        Term t = new Term(field, BytesRef.deepCopyOf(termAtt.getBytesRef()));
        if(termArr[0] == null) {
            termArr[0] = t;
            offsetArr[0] = offsetAtt.startOffset();
        } else if(termArr[1] == null) {
            termArr[1] = t;
            offsetArr[1] = offsetAtt.startOffset();
        } else {
            // shift
            termArr[0] = termArr[1];
            offsetArr[0] = offsetArr[1];
            // fill
            termArr[1] = t;
            offsetArr[1] = offsetAtt.startOffset();
        }
        
        if(termArr[0] != null && termArr[1] != null) {
            long offsetDiff = offsetArr[1] - offsetArr[0];
            if(offsetDiff > 0) {
                PhraseQuery.Builder pq = new PhraseQuery.Builder();

                pq.setSlop((int) (offsetDiff) + 1);
                pq.add(termArr[0]);
                pq.add(termArr[1]);

                builder.add(pq.build(), BooleanClause.Occur.SHOULD);
            }
        }
    }
}
 
開發者ID:iychoi,項目名稱:biospectra,代碼行數:40,代碼來源:Classifier.java

示例6: search

import org.apache.lucene.search.PhraseQuery; //導入方法依賴的package包/類
@Override
public List<Song> search(IndexType indexType, String searchString, FieldName... fieldsToSearchIn) {
	try {
		Directory directory = getIndex(indexType);
		IndexReader indexReader = DirectoryReader.open(directory);
		IndexSearcher indexSearcher = new IndexSearcher(indexReader);
		
		BooleanQuery.Builder outerBooleanQueryBuilder = new BooleanQuery.Builder();
		for (FieldName field : fieldsToSearchIn) {
			PhraseQuery.Builder phraseQueryBuilder = new PhraseQuery.Builder();
			for (String searchTerm : searchString.toLowerCase().split(TERM_SPLIT_REGEX)) {
				phraseQueryBuilder.add(new Term(field.name(), searchTerm));
			}
			PhraseQuery phraseQuery = phraseQueryBuilder.build();
			outerBooleanQueryBuilder.add(phraseQuery, Occur.SHOULD);
		}
		BooleanQuery outerBooleanQuery = outerBooleanQueryBuilder.build();
		TopDocs hits = indexSearcher.search(outerBooleanQuery, Integer.MAX_VALUE);
		
		LOG.debug("{} hits for filter \"{}\"", hits.totalHits, outerBooleanQueryBuilder);
		
		List<Song> ret = new LinkedList<>();
		for (ScoreDoc scoreDocument : hits.scoreDocs) {
			Document document;
			document = indexSearcher.doc(scoreDocument.doc);
			String uuid = document.get(FieldName.UUID.name());
			ret.add(songByUuid.get(uuid));
		}
		return ret;
	} catch (Exception e) {
		LOG.warn("problem while searching", e);
		return new ArrayList<>(0);
	}
}
 
開發者ID:mathisdt,項目名稱:sdb2,代碼行數:35,代碼來源:IndexerServiceImpl.java

示例7: addSlopToPhrase

import org.apache.lucene.search.PhraseQuery; //導入方法依賴的package包/類
/**
 * Rebuild a phrase query with a slop value
 */
private PhraseQuery addSlopToPhrase(PhraseQuery query, int slop) {
	PhraseQuery.Builder builder = new PhraseQuery.Builder();
	builder.setSlop(slop);
	org.apache.lucene.index.Term[] terms = query.getTerms();
	int[] positions = query.getPositions();
	for (int i = 0; i < terms.length; ++i) {
		builder.add(terms[i], positions[i]);
	}

	return builder.build();
}
 
開發者ID:easynet-cn,項目名稱:resource-query-parser,代碼行數:15,代碼來源:QueryParserBase.java

示例8: testMultiWordSynonyms

import org.apache.lucene.search.PhraseQuery; //導入方法依賴的package包/類
@Test
public void testMultiWordSynonyms() throws Exception {
	QueryParser dumb = new QueryParser("field", new Analyzer1());
	dumb.setSplitOnWhitespace(false);

	TermQuery guinea = new TermQuery(new Term("field", "guinea"));
	TermQuery pig = new TermQuery(new Term("field", "pig"));
	TermQuery cavy = new TermQuery(new Term("field", "cavy"));

	// A multi-word synonym source will form a graph query for synonyms that
	// formed the graph token stream
	BooleanQuery.Builder synonym = new BooleanQuery.Builder();
	synonym.add(guinea, BooleanClause.Occur.SHOULD);
	synonym.add(pig, BooleanClause.Occur.SHOULD);
	BooleanQuery guineaPig = synonym.build();

	// With the phrase operator, a multi-word synonym source will form a
	// graph query with inner phrase queries.
	PhraseQuery.Builder phraseSynonym = new PhraseQuery.Builder();
	phraseSynonym.add(new Term("field", "guinea"));
	phraseSynonym.add(new Term("field", "pig"));
	PhraseQuery guineaPigPhrase = phraseSynonym.build();

	// custom behavior, the synonyms are expanded, unless you use quote
	// operator
	QueryParser smart = new SmartQueryParser();
	smart.setSplitOnWhitespace(false);
	Assert.assertEquals(guineaPigPhrase, smart.parse("\"guinea pig\""));
}
 
開發者ID:easynet-cn,項目名稱:resource-query-parser,代碼行數:30,代碼來源:TestQueryParser.java

示例9: testPhraseQueryPositionIncrements

import org.apache.lucene.search.PhraseQuery; //導入方法依賴的package包/類
@Test
public void testPhraseQueryPositionIncrements() throws Exception {
	CharacterRunAutomaton stopStopList = new CharacterRunAutomaton(new RegExp("[sS][tT][oO][pP]").toAutomaton());

	QueryParser qp = getParserConfig(new MockAnalyzer(random(), MockTokenizer.WHITESPACE, false, stopStopList));
	qp.setEnablePositionIncrements(true);

	PhraseQuery.Builder phraseQuery = new PhraseQuery.Builder();
	phraseQuery.add(new Term("field", "1"));
	phraseQuery.add(new Term("field", "2"), 2);
	Assert.assertEquals(phraseQuery.build(), getQuery("\"1 stop 2\"", qp));
}
 
開發者ID:easynet-cn,項目名稱:resource-query-parser,代碼行數:13,代碼來源:QueryParserTestBase.java

示例10: testPhraseQueryPositionIncrements

import org.apache.lucene.search.PhraseQuery; //導入方法依賴的package包/類
public void testPhraseQueryPositionIncrements() throws Exception {
  CharacterRunAutomaton stopStopList =
      new CharacterRunAutomaton(new RegExp("[sS][tT][oO][pP]").toAutomaton());

  CommonQueryParserConfiguration qp = getParserConfig(new MockAnalyzer(random(), MockTokenizer.WHITESPACE, false, stopStopList));

  qp = getParserConfig(
      new MockAnalyzer(random(), MockTokenizer.WHITESPACE, false, stopStopList));
  qp.setEnablePositionIncrements(true);

  PhraseQuery.Builder phraseQuery = new PhraseQuery.Builder();
  phraseQuery.add(new Term("field", "1"));
  phraseQuery.add(new Term("field", "2"), 2);
  assertEquals(phraseQuery.build(), getQuery("\"1 stop 2\"",qp));
}
 
開發者ID:tballison,項目名稱:lucene-addons,代碼行數:16,代碼來源:QueryParserTestBase.java

示例11: createPairedProximityQueryClauses

import org.apache.lucene.search.PhraseQuery; //導入方法依賴的package包/類
private void createPairedProximityQueryClauses(BooleanQuery.Builder builder, String field, CachingTokenFilter stream, TermToBytesRefAttribute termAtt, OffsetAttribute offsetAtt) throws IOException {
    Term termArr[] = new Term[2];
    long offsetArr[] = new long[2];
    for(int i=0;i<2;i++) {
        termArr[i] = null;
        offsetArr[i] = 0;
    }

    int count = 0;
    while (stream.incrementToken()) {
        Term t = new Term(field, BytesRef.deepCopyOf(termAtt.getBytesRef()));
        if(count % 2 == 0) {
            termArr[0] = t;
            offsetArr[0] = offsetAtt.startOffset();
        } else {
            termArr[1] = t;
            offsetArr[1] = offsetAtt.startOffset();

            long offsetDiff = offsetArr[1] - offsetArr[0];
            if(offsetDiff > 0) {
                PhraseQuery.Builder pq = new PhraseQuery.Builder();

                pq.setSlop((int) (offsetDiff) + 1);
                pq.add(termArr[0]);
                pq.add(termArr[1]);

                builder.add(pq.build(), BooleanClause.Occur.SHOULD);
            }

            termArr[0] = null;
            termArr[1] = null;
        }

        count++;
    }
    
    if(termArr[0] != null) {
        builder.add(new TermQuery(termArr[0]), BooleanClause.Occur.SHOULD);
        termArr[0] = null;
    }
}
 
開發者ID:iychoi,項目名稱:biospectra,代碼行數:42,代碼來源:Classifier.java


注:本文中的org.apache.lucene.search.PhraseQuery.Builder方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。