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


Java InvalidTokenOffsetsException類代碼示例

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


InvalidTokenOffsetsException類屬於org.apache.lucene.search.highlight包,在下文中一共展示了InvalidTokenOffsetsException類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: checkGeoQueryHighlighting

import org.apache.lucene.search.highlight.InvalidTokenOffsetsException; //導入依賴的package包/類
public void checkGeoQueryHighlighting(Query geoQuery) throws IOException, InvalidTokenOffsetsException {
    Map analysers = new HashMap<String, Analyzer>();
    analysers.put("text", new StandardAnalyzer());
    FieldNameAnalyzer fieldNameAnalyzer = new FieldNameAnalyzer(analysers);
    Query termQuery = new TermQuery(new Term("text", "failure"));
    Query boolQuery = new BooleanQuery.Builder().add(new BooleanClause(geoQuery, BooleanClause.Occur.SHOULD))
        .add(new BooleanClause(termQuery, BooleanClause.Occur.SHOULD)).build();
    org.apache.lucene.search.highlight.Highlighter highlighter =
        new org.apache.lucene.search.highlight.Highlighter(new CustomQueryScorer(boolQuery));
    String fragment = highlighter.getBestFragment(fieldNameAnalyzer.tokenStream("text", "Arbitrary text field which should not cause " +
        "a failure"), "Arbitrary text field which should not cause a failure");
    assertThat(fragment, equalTo("Arbitrary text field which should not cause a <B>failure</B>"));
    Query rewritten = boolQuery.rewrite(null);
    highlighter = new org.apache.lucene.search.highlight.Highlighter(new CustomQueryScorer(rewritten));
    fragment = highlighter.getBestFragment(fieldNameAnalyzer.tokenStream("text", "Arbitrary text field which should not cause " +
        "a failure"), "Arbitrary text field which should not cause a failure");
    assertThat(fragment, equalTo("Arbitrary text field which should not cause a <B>failure</B>"));
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:19,代碼來源:PlainHighlighterTests.java

示例2: selectOnlyNotAlreadyIndexedFilesFromACollection

import org.apache.lucene.search.highlight.InvalidTokenOffsetsException; //導入依賴的package包/類
/**
 * Select only not already indexed files from a collection.
 *
 * @param fileCollection the file collection
 * @param location the location
 * @return the linked list
 * @throws IOException Signals that an I/O exception has occurred.
 * @throws ParseException the parse exception
 * @throws InvalidTokenOffsetsException the invalid token offsets exception
 */
// Return the collection with extracted (not indexed) Files
public static LinkedList<File> selectOnlyNotAlreadyIndexedFilesFromACollection(List<File> fileCollection, String location) throws IOException, ParseException, InvalidTokenOffsetsException {
	// Getting the path of our index and opens a reader to read the index in the current folder
	Path dirPath = Paths.get(location);
	FSDirectory dir = FSDirectory.open(dirPath);
	DirectoryReader indexReader = DirectoryReader.open(dir);
	LinkedList<File> onlyNotIndexedFiles = new LinkedList<File>();
	
	for (File file : fileCollection) {
		// Creates new Term using the path of the html file 
		Term indexTerm = new Term("path", file.getPath());
					
		// Checks if a document in the index has the same path
		if (indexReader.docFreq(indexTerm) > 0)
		{
			// If yes do not add the document
			continue;
		}
		else {
			onlyNotIndexedFiles.add(file);
		}
	}
	indexReader.close();
	return onlyNotIndexedFiles;
}
 
開發者ID:IvanGrigorov,項目名稱:Neutrino-Search-Engine,代碼行數:36,代碼來源:Indexer.java

示例3: highlight

import org.apache.lucene.search.highlight.InvalidTokenOffsetsException; //導入依賴的package包/類
String highlight(String fieldName, String text) {
  if (text == null) {
    return null;
  }

  try {
    String highlighted = highlighter.getBestFragment(analyzer, fieldName, text);
    if (highlighted == null) {
      return null;
    }

    highlighted = cleanUpPattern.matcher(highlighted).replaceAll("");
    highlighted = replaceLFPattern.matcher(highlighted).replaceAll(" ");
    if (highlighted.isEmpty()) {
      highlighted = null;
    }

    return highlighted;
  } catch (InvalidTokenOffsetsException|IOException e) {
    return null;
  }
}
 
開發者ID:lukhnos,項目名稱:lucenestudy,代碼行數:23,代碼來源:HighlightingHelper.java

示例4: searToHighlighterCss

import org.apache.lucene.search.highlight.InvalidTokenOffsetsException; //導入依賴的package包/類
/**
 * ����
 * @param analyzer
 * @param searcher
 * @throws IOException
 * @throws InvalidTokenOffsetsException
 */
public void searToHighlighterCss(Analyzer analyzer,IndexSearcher searcher) throws IOException, InvalidTokenOffsetsException{  
       Term term =new Term("Content", new String("免費".getBytes(),"GBK"));//��ѯ��������˼����Ҫ�����Ա�Ϊ���������  
       TermQuery query =new TermQuery(term);  
       TopDocs docs =searcher.search(query, 10);//����  
         
       /**�Զ����ע�����ı���ǩ*/  
       SimpleHTMLFormatter formatter = new SimpleHTMLFormatter("<span class=\"hightlighterCss\">","</span>");  
       /**����QueryScorer*/  
       QueryScorer scorer=new QueryScorer(query);  
       /**����Fragmenter*/  
       Fragmenter fragmenter = new SimpleSpanFragmenter(scorer);  
       Highlighter highlight=new Highlighter(formatter,scorer);  
       highlight.setTextFragmenter(fragmenter);  
       
       for(ScoreDoc doc:docs.scoreDocs){//��ȡ���ҵ��ĵ����������
           Document document =searcher.doc(doc.doc);
           String value = document.getField("Content").toString();
           TokenStream tokenStream = analyzer.tokenStream("Content", new StringReader(value));    
           String str1 = highlight.getBestFragment(tokenStream, value);    
           System.out.println(str1);
       }  
   }
 
開發者ID:Smalinuxer,項目名稱:Rearchor,代碼行數:30,代碼來源:TestHighLight.java

示例5: translateDocs

import org.apache.lucene.search.highlight.InvalidTokenOffsetsException; //導入依賴的package包/類
/**
 * 
 * @throws IOException
 * @throws InvalidTokenOffsetsException
 */
private List<Person> translateDocs(final LuceneIndex<Person> luceneDb, final IndexSearcher searcher, final TopDocs topDocs, final Query query) throws IOException, InvalidTokenOffsetsException {
	final List<Person> dtcResult = new ArrayList<>();
	for (final ScoreDoc scoreDoc : topDocs.scoreDocs) {
		final Document document = searcher.doc(scoreDoc.doc);
		final Person dto = luceneDb.getObjectIndexed(document.get(UUID_KEY));
		dto.setScore(Math.round(scoreDoc.score / Math.max(topDocs.getMaxScore(), 2.5f) * 100));
		dtcResult.add(dto);

		//final QueryScorer queryScorer = new QueryScorer(query);
		//final Highlighter highlighter = new Highlighter(queryScorer);
		//highlighter.setTextFragmenter(new SimpleSpanFragmenter(queryScorer, Integer.MAX_VALUE));
		//highlighter.setMaxDocCharsToAnalyze(Integer.MAX_VALUE);
		//final String[] strings = highlighter.getBestFragments(indexAnalyser, "fullname", dto.getName() + " " + dto.getFirstname(), 5);
		//System.out.println("found: " + Arrays.toString(strings));
	}
	return dtcResult;
}
 
開發者ID:KleeGroup,項目名稱:vertigo-labs,代碼行數:23,代碼來源:LuceneIndexPlugin.java

示例6: highlight

import org.apache.lucene.search.highlight.InvalidTokenOffsetsException; //導入依賴的package包/類
@Override
public String highlight(String locale, boolean useStopWords, String query, String content, String pre, String post, int preview) {
    Analyzer analyzer = termAnalyzers.findAnalyzer(locale, useStopWords);
    QueryParser parser = new QueryParser(defaultField, analyzer);

    String summary = null;
    try {
        SimpleHTMLFormatter formatter = new SimpleHTMLFormatter(pre, post);
        Highlighter hg = new Highlighter(formatter, new QueryTermScorer(parser.parse(query)));
        hg.setMaxDocCharsToAnalyze(preview);
        hg.setTextFragmenter(new SimpleFragmenter(100));

        TokenStream tokens = TokenSources.getTokenStream(defaultField, content, analyzer);
        summary = hg.getBestFragments(tokens, content, 4, " ... ");
    } catch (InvalidTokenOffsetsException | IOException | ParseException ex) {
        LOG.error("Failed to highlight", ex);
    }

    return StringUtils.isBlank(summary) ? null : summary;
}
 
開發者ID:jivesoftware,項目名稱:miru,代碼行數:21,代碼來源:LuceneBackedQueryParser.java

示例7: highlightField

import org.apache.lucene.search.highlight.InvalidTokenOffsetsException; //導入依賴的package包/類
/**
 * This method intended for use with
 * <tt>testHighlightingWithDefaultField()</tt>
 */
private String highlightField(Query query, String fieldName,
    String text) throws IOException, InvalidTokenOffsetsException {
  TokenStream tokenStream = new MockAnalyzer(random(), MockTokenizer.SIMPLE,
      true, MockTokenFilter.ENGLISH_STOPSET, true).tokenStream(fieldName,
      new StringReader(text));
  // Assuming "<B>", "</B>" used to highlight
  SimpleHTMLFormatter formatter = new SimpleHTMLFormatter();
  MyQueryScorer scorer = new MyQueryScorer(query, fieldName, FIELD_NAME);
  Highlighter highlighter = new Highlighter(formatter, scorer);
  highlighter.setTextFragmenter(new SimpleFragmenter(Integer.MAX_VALUE));

  String rv = highlighter.getBestFragments(tokenStream, text, 1,
      "(FIELD TEXT TRUNCATED)");
  return rv.length() == 0 ? text : rv;
}
 
開發者ID:pkarmstr,項目名稱:NYBC,代碼行數:20,代碼來源:HighlightCustomQueryTest.java

示例8: displayHtmlHighlight

import org.apache.lucene.search.highlight.InvalidTokenOffsetsException; //導入依賴的package包/類
static String displayHtmlHighlight(Query query, Analyzer analyzer, String fieldName, String fieldContent,
		int fragmentSize) throws IOException, InvalidTokenOffsetsException {
	Highlighter highlighter = new Highlighter(new SimpleHTMLFormatter("<font color='red'>", "</font>"),
			new QueryScorer(query));
	Fragmenter fragmenter = new SimpleFragmenter(fragmentSize);
	highlighter.setTextFragmenter(fragmenter);
	return highlighter.getBestFragment(analyzer, fieldName, fieldContent);
}
 
開發者ID:tedyli,項目名稱:Tedyli-Searcher,代碼行數:9,代碼來源:Searcher.java

示例9: performHighlighting

import org.apache.lucene.search.highlight.InvalidTokenOffsetsException; //導入依賴的package包/類
/**
 * Performs highlighting for a given query and a given document.
 *
 * @param indexSearcher the IndexSearcher performing the query
 * @param query the Tripod LuceneQuery
 * @param scoreDoc the Lucene ScoreDoc
 * @param doc the Lucene Document
 * @param highlighter the Highlighter to use
 * @param result the QueryResult to add the highlights to
 * @throws IOException if an error occurs performing the highlighting
 * @throws InvalidTokenOffsetsException if an error occurs performing the highlighting
 */
protected void performHighlighting(final IndexSearcher indexSearcher, final Query query, final ScoreDoc scoreDoc,
                                   final Document doc, final Highlighter highlighter, final QR result)
        throws IOException, InvalidTokenOffsetsException {

    if (query.getHighlightFields() == null || query.getHighlightFields().isEmpty()) {
        return;
    }

    final List<Highlight> highlights = new ArrayList<>();
    final List<String> hlFieldNames = getHighlightFieldNames(query, doc);

    // process each field to highlight on
    for (String hlField : hlFieldNames) {
        final String text = doc.get(hlField);
        if (StringUtils.isEmpty(text)) {
            continue;
        }

        final List<String> snippets = new ArrayList<>();
        final Fields tvFields = indexSearcher.getIndexReader().getTermVectors(scoreDoc.doc);
        final int maxStartOffset = highlighter.getMaxDocCharsToAnalyze() -1;

        // get the snippets for the given field
        final TokenStream tokenStream = TokenSources.getTokenStream(hlField, tvFields, text, analyzer, maxStartOffset);
        final TextFragment[] textFragments = highlighter.getBestTextFragments(tokenStream, text, false, 10);
        for (TextFragment textFragment : textFragments) {
            if (textFragment != null && textFragment.getScore() > 0) {
                snippets.add(textFragment.toString());
            }
        }

        // if we have snippets then add a highlight result to the QueryResult
        if (snippets.size() > 0) {
            highlights.add(new Highlight(hlField, snippets));
        }
    }

    result.setHighlights(highlights);
}
 
開發者ID:bbende,項目名稱:tripod,代碼行數:52,代碼來源:LuceneService.java

示例10: search

import org.apache.lucene.search.highlight.InvalidTokenOffsetsException; //導入依賴的package包/類
@ResponseBody
@RequestMapping(value = "/search/{key}", method = RequestMethod.GET, 
			produces="application/json;charset=UTF-8")
public String search(@PathVariable String key) throws IOException, 
		ParseException, InvalidTokenOffsetsException {
	return searchData(key);
}
 
開發者ID:tensorchen,項目名稱:rrs,代碼行數:8,代碼來源:SearchController.java

示例11: testHighlightCustomQuery

import org.apache.lucene.search.highlight.InvalidTokenOffsetsException; //導入依賴的package包/類
public void testHighlightCustomQuery() throws IOException,
    InvalidTokenOffsetsException {
  String s1 = "I call our world Flatland, not because we call it so,";

  // Verify that a query against the default field results in text being
  // highlighted
  // regardless of the field name.

  CustomQuery q = new CustomQuery(new Term(FIELD_NAME, "world"));

  String expected = "I call our <B>world</B> Flatland, not because we call it so,";
  String observed = highlightField(q, "SOME_FIELD_NAME", s1);
  if (VERBOSE)
    System.out.println("Expected: \"" + expected + "\n" + "Observed: \""
        + observed);
  assertEquals(
      "Query in the default field results in text for *ANY* field being highlighted",
      expected, observed);

  // Verify that a query against a named field does not result in any
  // highlighting
  // when the query field name differs from the name of the field being
  // highlighted,
  // which in this example happens to be the default field name.
  q = new CustomQuery(new Term("text", "world"));

  expected = s1;
  observed = highlightField(q, FIELD_NAME, s1);
  if (VERBOSE)
    System.out.println("Expected: \"" + expected + "\n" + "Observed: \""
        + observed);
  assertEquals(
      "Query in a named field does not result in highlighting when that field isn't in the query",
      s1, highlightField(q, FIELD_NAME, s1));

}
 
開發者ID:europeana,項目名稱:search,代碼行數:37,代碼來源:HighlightCustomQueryTest.java

示例12: highlightField

import org.apache.lucene.search.highlight.InvalidTokenOffsetsException; //導入依賴的package包/類
/**
 * This method intended for use with
 * <tt>testHighlightingWithDefaultField()</tt>
 */
private String highlightField(Query query, String fieldName,
    String text) throws IOException, InvalidTokenOffsetsException {
  TokenStream tokenStream = new MockAnalyzer(random(), MockTokenizer.SIMPLE,
      true, MockTokenFilter.ENGLISH_STOPSET).tokenStream(fieldName, text);
  // Assuming "<B>", "</B>" used to highlight
  SimpleHTMLFormatter formatter = new SimpleHTMLFormatter();
  MyQueryScorer scorer = new MyQueryScorer(query, fieldName, FIELD_NAME);
  Highlighter highlighter = new Highlighter(formatter, scorer);
  highlighter.setTextFragmenter(new SimpleFragmenter(Integer.MAX_VALUE));

  String rv = highlighter.getBestFragments(tokenStream, text, 1,
      "(FIELD TEXT TRUNCATED)");
  return rv.length() == 0 ? text : rv;
}
 
開發者ID:europeana,項目名稱:search,代碼行數:19,代碼來源:HighlightCustomQueryTest.java

示例13: doHighlight

import org.apache.lucene.search.highlight.InvalidTokenOffsetsException; //導入依賴的package包/類
/**
 * Highlight (bold,color) query words in result-document. Set HighlightResult for content or description.
 * 
 * @param query
 * @param analyzer
 * @param doc
 * @param resultDocument
 * @throws IOException
 */
private void doHighlight(final Query query, final Analyzer analyzer, final Document doc, final ResultDocument resultDocument) throws IOException {
    final Highlighter highlighter = new Highlighter(new SimpleHTMLFormatter(HIGHLIGHT_PRE_TAG, HIGHLIGHT_POST_TAG), new QueryScorer(query));
    // Get 3 best fragments of content and seperate with a "..."
    try {
        // highlight content
        final String content = doc.get(AbstractOlatDocument.CONTENT_FIELD_NAME);
        TokenStream tokenStream = analyzer.tokenStream(AbstractOlatDocument.CONTENT_FIELD_NAME, new StringReader(content));
        String highlightResult = highlighter.getBestFragments(tokenStream, content, 3, HIGHLIGHT_SEPARATOR);

        // if no highlightResult is in content => look in description
        if (highlightResult.length() == 0) {
            final String description = doc.get(AbstractOlatDocument.DESCRIPTION_FIELD_NAME);
            tokenStream = analyzer.tokenStream(AbstractOlatDocument.DESCRIPTION_FIELD_NAME, new StringReader(description));
            highlightResult = highlighter.getBestFragments(tokenStream, description, 3, HIGHLIGHT_SEPARATOR);
            resultDocument.setHighlightingDescription(true);
        }
        resultDocument.setHighlightResult(highlightResult);

        // highlight title
        final String title = doc.get(AbstractOlatDocument.TITLE_FIELD_NAME);
        tokenStream = analyzer.tokenStream(AbstractOlatDocument.TITLE_FIELD_NAME, new StringReader(title));
        final String highlightTitle = highlighter.getBestFragments(tokenStream, title, 3, " ");
        resultDocument.setHighlightTitle(highlightTitle);
    } catch (final InvalidTokenOffsetsException e) {
        log.warn("", e);
    }
}
 
開發者ID:huihoo,項目名稱:olat,代碼行數:37,代碼來源:SearchResultsImpl.java

示例14: executeQuery

import org.apache.lucene.search.highlight.InvalidTokenOffsetsException; //導入依賴的package包/類
private List<Person> executeQuery(final LuceneIndex<Person> luceneDb, final Query query, final int maxRow) throws IOException, InvalidTokenOffsetsException {
	try (final IndexReader indexReader = luceneDb.createIndexReader()) {
		final IndexSearcher searcher = new IndexSearcher(indexReader);
		//1. Exécution des la Requête
		final TopDocs topDocs = searcher.search(query, null, maxRow);

		//2. Traduction du résultat Lucene en une Collection
		return translateDocs(luceneDb, searcher, topDocs, query);
	} catch (final TooManyClauses e) {
		throw new RuntimeException("Too many clauses", e);
	}
}
 
開發者ID:KleeGroup,項目名稱:vertigo-labs,代碼行數:13,代碼來源:LuceneIndexPlugin.java

示例15: testGeoPointInBBoxQueryHighlighting

import org.apache.lucene.search.highlight.InvalidTokenOffsetsException; //導入依賴的package包/類
public void testGeoPointInBBoxQueryHighlighting() throws IOException, InvalidTokenOffsetsException {
    Query geoQuery = new GeoPointDistanceQuery("geo_point", -64.92354174306496, -170.15625, 5576757);
    checkGeoQueryHighlighting(geoQuery);
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:5,代碼來源:PlainHighlighterTests.java


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