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


Java AnalyzeResponse.getTokens方法代碼示例

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


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

示例1: assertIncludes

import org.elasticsearch.action.admin.indices.analyze.AnalyzeResponse; //導入方法依賴的package包/類
private void assertIncludes(String input, List<String> expectedTokens, List<String> fields) throws ExecutionException, InterruptedException, IOException {
    for (String field : fields) {
        AnalyzeResponse response = client().admin().indices().prepareAnalyze(input).setField(field).setIndex("test").execute().get();
        index("test", "type", "1", field, input);
        
        // Verify all the expected tokens are in there
        List<String> tokens = new ArrayList<String>();
        for (AnalyzeToken token : response.getTokens()) {
            assertFalse(StringUtils.isEmpty(token.getTerm()));
            tokens.add(token.getTerm());
        }
        
        flush();
        refresh();
        
        for (String expectedToken : expectedTokens) {
            assertTrue(tokens.contains(expectedToken));
            SearchResponse sr = client().prepareSearch("test").setQuery(QueryBuilders.termQuery(field, expectedToken)).execute().actionGet();
            assertThat(sr.getHits().getTotalHits(), is(1L));
            sr = client().prepareSearch("test").setQuery(QueryBuilders.termQuery(field, "bogussearchterm")).execute().actionGet();
            assertThat(sr.getHits().getTotalHits(), is(0l));
        }
    }
}
 
開發者ID:MyPureCloud,項目名稱:elasticsearch-phone,代碼行數:25,代碼來源:PhoneTokenizerIntegrationTest.java

示例2: testNoIndexAnalyzers

import org.elasticsearch.action.admin.indices.analyze.AnalyzeResponse; //導入方法依賴的package包/類
public void testNoIndexAnalyzers() throws IOException {
    AnalyzeRequest request = new AnalyzeRequest();
    request.analyzer("standard");
    request.text("the quick brown fox");
    AnalyzeResponse analyze = TransportAnalyzeAction.analyze(request, AllFieldMapper.NAME, null, null, registry, environment);
    List<AnalyzeResponse.AnalyzeToken> tokens = analyze.getTokens();
    assertEquals(4, tokens.size());

    request.analyzer(null);
    request.tokenizer("whitespace");
    request.addTokenFilter("lowercase");
    request.addTokenFilter("word_delimiter");
    request.text("the qu1ck brown fox");
    analyze = TransportAnalyzeAction.analyze(request, AllFieldMapper.NAME, null, randomBoolean() ? indexAnalyzers : null, registry, environment);
    tokens = analyze.getTokens();
    assertEquals(6, tokens.size());
    assertEquals("qu", tokens.get(1).getTerm());
    assertEquals("1", tokens.get(2).getTerm());
    assertEquals("ck", tokens.get(3).getTerm());

    request.analyzer(null);
    request.tokenizer("whitespace");
    request.addCharFilter("html_strip");
    request.addTokenFilter("lowercase");
    request.addTokenFilter("word_delimiter");
    request.text("<p>the qu1ck brown fox</p>");
    analyze = TransportAnalyzeAction.analyze(request, AllFieldMapper.NAME, null, randomBoolean() ? indexAnalyzers : null, registry, environment);
    tokens = analyze.getTokens();
    assertEquals(6, tokens.size());
    assertEquals("the", tokens.get(0).getTerm());
    assertEquals("qu", tokens.get(1).getTerm());
    assertEquals("1", tokens.get(2).getTerm());
    assertEquals("ck", tokens.get(3).getTerm());
    assertEquals("brown", tokens.get(4).getTerm());
    assertEquals("fox", tokens.get(5).getTerm());
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:37,代碼來源:TransportAnalyzeActionTests.java

示例3: testFillsAttributes

import org.elasticsearch.action.admin.indices.analyze.AnalyzeResponse; //導入方法依賴的package包/類
public void testFillsAttributes() throws IOException {
    AnalyzeRequest request = new AnalyzeRequest();
    request.analyzer("standard");
    request.text("the 1 brown fox");
    AnalyzeResponse analyze = TransportAnalyzeAction.analyze(request, AllFieldMapper.NAME, null, null, registry, environment);
    List<AnalyzeResponse.AnalyzeToken> tokens = analyze.getTokens();
    assertEquals(4, tokens.size());
    assertEquals("the", tokens.get(0).getTerm());
    assertEquals(0, tokens.get(0).getStartOffset());
    assertEquals(3, tokens.get(0).getEndOffset());
    assertEquals(0, tokens.get(0).getPosition());
    assertEquals("<ALPHANUM>", tokens.get(0).getType());

    assertEquals("1", tokens.get(1).getTerm());
    assertEquals(4, tokens.get(1).getStartOffset());
    assertEquals(5, tokens.get(1).getEndOffset());
    assertEquals(1, tokens.get(1).getPosition());
    assertEquals("<NUM>", tokens.get(1).getType());

    assertEquals("brown", tokens.get(2).getTerm());
    assertEquals(6, tokens.get(2).getStartOffset());
    assertEquals(11, tokens.get(2).getEndOffset());
    assertEquals(2, tokens.get(2).getPosition());
    assertEquals("<ALPHANUM>", tokens.get(2).getType());

    assertEquals("fox", tokens.get(3).getTerm());
    assertEquals(12, tokens.get(3).getStartOffset());
    assertEquals(15, tokens.get(3).getEndOffset());
    assertEquals(3, tokens.get(3).getPosition());
    assertEquals("<ALPHANUM>", tokens.get(3).getType());
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:32,代碼來源:TransportAnalyzeActionTests.java

示例4: testNonPreBuildTokenFilter

import org.elasticsearch.action.admin.indices.analyze.AnalyzeResponse; //導入方法依賴的package包/類
public void testNonPreBuildTokenFilter() throws IOException {
    AnalyzeRequest request = new AnalyzeRequest();
    request.tokenizer("whitespace");
    request.addTokenFilter("min_hash");
    request.text("the quick brown fox");
    AnalyzeResponse analyze = TransportAnalyzeAction.analyze(request, AllFieldMapper.NAME, null, indexAnalyzers, registry, environment);
    List<AnalyzeResponse.AnalyzeToken> tokens = analyze.getTokens();
    int default_hash_count = 1;
    int default_bucket_size = 512;
    int default_hash_set_size = 1;
    assertEquals(default_hash_count * default_bucket_size * default_hash_set_size, tokens.size());

}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:14,代碼來源:TransportAnalyzeActionTests.java

示例5: customAnalyzing

import org.elasticsearch.action.admin.indices.analyze.AnalyzeResponse; //導入方法依賴的package包/類
public String customAnalyzing(String indexName, String analyzer, String str) throws InterruptedException, ExecutionException {
  String[] strList = str.toLowerCase().split(",");
  for (int i = 0; i < strList.length; i++) {
    String tmp = "";
    AnalyzeResponse r = client.admin().indices().prepareAnalyze(strList[i]).setIndex(indexName).setAnalyzer(analyzer).execute().get();
    for (AnalyzeToken token : r.getTokens()) {
      tmp += token.getTerm() + " ";
    }
    strList[i] = tmp.trim();
  }
  return String.join(",", strList);
}
 
開發者ID:apache,項目名稱:incubator-sdap-mudrod,代碼行數:13,代碼來源:ESDriver.java

示例6: showAnaylzerText

import org.elasticsearch.action.admin.indices.analyze.AnalyzeResponse; //導入方法依賴的package包/類
private static void showAnaylzerText(IndicesAdminClient indicesAdminClient,String analyzerName, String text) {
    AnalyzeResponse analyzeResponse = indicesAdminClient.analyze(new AnalyzeRequest(INDEX_NAME).analyzer(analyzerName).text(text)).actionGet();
    List<AnalyzeResponse.AnalyzeToken> token=analyzeResponse.getTokens();
    for (AnalyzeResponse.AnalyzeToken analyzeToken : token) {
        log.info(analyzerName+": {}",analyzeToken.getTerm());
    }

}
 
開發者ID:ggj2010,項目名稱:javabase,代碼行數:9,代碼來源:CrudDemo.java

示例7: analyze

import org.elasticsearch.action.admin.indices.analyze.AnalyzeResponse; //導入方法依賴的package包/類
/**
 * 分詞-無法分詞則返回空集合
 * 
 * @param analyzer
 * @param str
 * @return
 */
public static List<String> analyze(String analyzer, String str) {

    AnalyzeResponse ar = null;
    try {
        AnalyzeRequest request = new AnalyzeRequest(str).analyzer(analyzer).index(
                getCurrentValidIndex());
        ar = ESClient.getClient().admin().indices().analyze(request).actionGet();
    } catch (IndexMissingException e) {
        if (!reLoad) {
            synchronized (AnalyzeHelper.class) {
                if (!reLoad) {
                    reLoad = true;
                }
            }
        }
        return analyze(analyzer, str);
    }

    if (ar == null || ar.getTokens() == null || ar.getTokens().size() < 1) {
        return Lists.newArrayList();
    }
    List<String> analyzeTokens = Lists.newArrayList();
    for (AnalyzeToken at : ar.getTokens()) {
        analyzeTokens.add(at.getTerm());
    }
    return analyzeTokens;
}
 
開發者ID:hailin0,項目名稱:es-service-parent,代碼行數:35,代碼來源:AnalyzeHelper.java

示例8: analyzeText

import org.elasticsearch.action.admin.indices.analyze.AnalyzeResponse; //導入方法依賴的package包/類
@Override
public List<String> analyzeText(final String indexAliasName, final String analyzer, final String[] tokenFilters, final String text)
{
    final List<String> tokens = new ArrayList<String>();
    final AnalyzeRequestBuilder analyzeRequestBuilder = searchClientService.getClient().admin().indices().prepareAnalyze(text);
    if (analyzer != null)
    {
        analyzeRequestBuilder.setIndex(indexAliasName);
    }
    if (analyzer != null)
    {
        analyzeRequestBuilder.setAnalyzer(analyzer);
    }
    if (tokenFilters != null)
    {
        analyzeRequestBuilder.setTokenFilters(tokenFilters);
    }
    logger.debug("Analyze request is text: {}, analyzer: {}, tokenfilters: {}", new Object[] { analyzeRequestBuilder.request().text(),
            analyzeRequestBuilder.request().analyzer(), analyzeRequestBuilder.request().tokenFilters() });
    final AnalyzeResponse analyzeResponse = analyzeRequestBuilder.get();
    try
    {
        if (analyzeResponse != null)
        {
            logger.debug("Analyze response is : {}", analyzeResponse.toXContent(jsonBuilder().startObject(), ToXContent.EMPTY_PARAMS)
                    .prettyPrint().string());
        }
    }
    catch (final IOException e)
    {
        logger.error("Error printing response.", e);
    }
    for (final AnalyzeToken analyzeToken : analyzeResponse.getTokens())
    {
        tokens.add(analyzeToken.getTerm());
    }
    return tokens;
}
 
開發者ID:jaibeermalik,項目名稱:elasticsearch-akka,代碼行數:39,代碼來源:SetupIndexServiceImpl.java

示例9: analyzeText

import org.elasticsearch.action.admin.indices.analyze.AnalyzeResponse; //導入方法依賴的package包/類
@Override
public List<String> analyzeText(final String indexAliasName,
		final String analyzer, final String[] tokenFilters,
		final String text) {
	final List<String> tokens = new ArrayList<String>();
	final AnalyzeRequestBuilder analyzeRequestBuilder = searchClientService
			.getClient().admin().indices().prepareAnalyze(text);
	if (analyzer != null) {
		analyzeRequestBuilder.setIndex(indexAliasName);
	}
	if (analyzer != null) {
		analyzeRequestBuilder.setAnalyzer(analyzer);
	}
	if (tokenFilters != null) {
		analyzeRequestBuilder.setTokenFilters(tokenFilters);
	}
	logger.debug(
			"Analyze request is text: {}, analyzer: {}, tokenfilters: {}",
			new Object[] { analyzeRequestBuilder.request().text(),
					analyzeRequestBuilder.request().analyzer(),
					analyzeRequestBuilder.request().tokenFilters() });
	final AnalyzeResponse analyzeResponse = analyzeRequestBuilder.get();
	try {
		if (analyzeResponse != null) {
			logger.debug(
					"Analyze response is : {}",
					analyzeResponse
							.toXContent(jsonBuilder().startObject(),
									ToXContent.EMPTY_PARAMS).prettyPrint()
							.string());
		}
	} catch (final IOException e) {
		logger.error("Error printing response.", e);
	}
	for (final AnalyzeToken analyzeToken : analyzeResponse.getTokens()) {
		tokens.add(analyzeToken.getTerm());
	}
	return tokens;
}
 
開發者ID:jaibeermalik,項目名稱:searchanalytics-bigdata,代碼行數:40,代碼來源:SetupIndexServiceImpl.java

示例10: normalize

import org.elasticsearch.action.admin.indices.analyze.AnalyzeResponse; //導入方法依賴的package包/類
@Override
public String normalize(final String text, final String... dummy) {
    final AnalyzeResponse termResponse =
            client.admin().indices().prepareAnalyze(analyzerSettings.getAnalyzerSettingsIndexName(), text)
                    .setAnalyzer(analyzerSettings.getNormalizeAnalyzerName(lang)).execute().actionGet();

    final List<AnalyzeResponse.AnalyzeToken> termTokenList = termResponse.getTokens();
    if (termTokenList.isEmpty()) {
        return text;
    }

    return termTokenList.get(0).getTerm();
}
 
開發者ID:codelibs,項目名稱:fess-suggest,代碼行數:14,代碼來源:AnalyzerNormalizer.java

示例11: analyze

import org.elasticsearch.action.admin.indices.analyze.AnalyzeResponse; //導入方法依賴的package包/類
@Override
public List<AnalyzeResponse.AnalyzeToken> analyze(final String text, final String lang) {
    final AnalyzeResponse analyzeResponse =
            client.admin().indices().prepareAnalyze(analyzerSettingsIndexName, text).setAnalyzer(getContentsAnalyzerName(lang))
                    .execute().actionGet();
    return analyzeResponse.getTokens();
}
 
開發者ID:codelibs,項目名稱:fess-suggest,代碼行數:8,代碼來源:AnalyzerSettings.java

示例12: analyzeAndReading

import org.elasticsearch.action.admin.indices.analyze.AnalyzeResponse; //導入方法依賴的package包/類
@Override
public List<AnalyzeResponse.AnalyzeToken> analyzeAndReading(final String text, final String lang) {
    try {
        final AnalyzeResponse analyzeResponse =
                client.admin().indices().prepareAnalyze(analyzerSettingsIndexName, text)
                        .setAnalyzer(getContentsReadingAnalyzerName(lang)).execute().actionGet();
        return analyzeResponse.getTokens();
    } catch (final IllegalArgumentException e) {
        return analyze(text, lang);
    }
}
 
開發者ID:codelibs,項目名稱:fess-suggest,代碼行數:12,代碼來源:AnalyzerSettings.java

示例13: testWithIndexAnalyzers

import org.elasticsearch.action.admin.indices.analyze.AnalyzeResponse; //導入方法依賴的package包/類
public void testWithIndexAnalyzers() throws IOException {

        AnalyzeRequest request = new AnalyzeRequest();
        request.analyzer("standard");
        request.text("the quick brown fox");
        request.analyzer("custom_analyzer");
        request.text("the qu1ck brown fox");
        AnalyzeResponse analyze = TransportAnalyzeAction.analyze(request, AllFieldMapper.NAME, null, indexAnalyzers, registry, environment);
        List<AnalyzeResponse.AnalyzeToken> tokens = analyze.getTokens();
        assertEquals(4, tokens.size());

        request.analyzer("whitespace");
        request.text("the qu1ck brown fox-dog");
        analyze = TransportAnalyzeAction.analyze(request, AllFieldMapper.NAME, null, indexAnalyzers, registry, environment);
        tokens = analyze.getTokens();
        assertEquals(4, tokens.size());

        request.analyzer("custom_analyzer");
        request.text("the qu1ck brown fox-dog");
        analyze = TransportAnalyzeAction.analyze(request, AllFieldMapper.NAME, null, indexAnalyzers, registry, environment);
        tokens = analyze.getTokens();
        assertEquals(5, tokens.size());

        request.analyzer(null);
        request.tokenizer("whitespace");
        request.addTokenFilter("lowercase");
        request.addTokenFilter("wordDelimiter");
        request.text("the qu1ck brown fox-dog");
        analyze = TransportAnalyzeAction.analyze(request, AllFieldMapper.NAME, null, indexAnalyzers, registry, environment);
        tokens = analyze.getTokens();
        assertEquals(5, tokens.size());
        assertEquals("the", tokens.get(0).getTerm());
        assertEquals("qu1ck", tokens.get(1).getTerm());
        assertEquals("brown", tokens.get(2).getTerm());
        assertEquals("fox", tokens.get(3).getTerm());
        assertEquals("dog", tokens.get(4).getTerm());

        request.analyzer(null);
        request.tokenizer("trigram");
        request.addTokenFilter("synonym");
        request.text("kimchy");
        analyze = TransportAnalyzeAction.analyze(request, AllFieldMapper.NAME, null, indexAnalyzers, registry, environment);
        tokens = analyze.getTokens();
        assertEquals(2, tokens.size());
        assertEquals("sha", tokens.get(0).getTerm());
        assertEquals("hay", tokens.get(1).getTerm());
    }
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:48,代碼來源:TransportAnalyzeActionTests.java

示例14: analyzeText

import org.elasticsearch.action.admin.indices.analyze.AnalyzeResponse; //導入方法依賴的package包/類
@Override
public List<String> analyzeText(String indexAliasName, String analyzer, String[] tokenFilters, String text)
{
    List<String> tokens = new ArrayList<String>();
    
    AnalyzeRequestBuilder analyzeRequestBuilder = searchClientService.getClient().admin().indices().prepareAnalyze(text);
    
    if(analyzer !=null)
    {
        analyzeRequestBuilder.setIndex(indexAliasName);
    }
    if(analyzer !=null)
    {
        analyzeRequestBuilder.setAnalyzer(analyzer);
    }
    
    if(tokenFilters !=null)
    {
        analyzeRequestBuilder.setTokenFilters(tokenFilters);
    }
    
    logger.debug("Analyze request is text: {}, analyzer: {}, tokenfilters: {}", new Object[]{analyzeRequestBuilder.request().text(), 
                                                                                analyzeRequestBuilder.request().analyzer(),
                                                                                analyzeRequestBuilder.request().tokenFilters()});
                                                                                        
    AnalyzeResponse analyzeResponse = analyzeRequestBuilder.get();
    
    try
    {
        if(analyzeResponse != null)
        {
            logger.debug("Analyze response is : {}", analyzeResponse.toXContent(jsonBuilder().startObject(), ToXContent.EMPTY_PARAMS).prettyPrint().string());
        }
    } catch (IOException e)
    {
        logger.error("Error printing response.", e);
    }
    
    for (AnalyzeToken analyzeToken : analyzeResponse.getTokens())
    {
        tokens.add(analyzeToken.getTerm());
    }
    return tokens;
}
 
開發者ID:jaibeermalik,項目名稱:elasticsearch-tutorial,代碼行數:45,代碼來源:SetupIndexServiceImpl.java

示例15: convert

import org.elasticsearch.action.admin.indices.analyze.AnalyzeResponse; //導入方法依賴的package包/類
@Override
public List<String> convert(final String text, final String... dummy) throws IOException {
    final AnalyzeResponse readingResponse =
            client.admin().indices().prepareAnalyze(analyzerSettings.getAnalyzerSettingsIndexName(), text)
                    .setAnalyzer(analyzerSettings.getReadingAnalyzerName(lang)).execute().actionGet();

    final AnalyzeResponse termResponse =
            client.admin().indices().prepareAnalyze(analyzerSettings.getAnalyzerSettingsIndexName(), text)
                    .setAnalyzer(analyzerSettings.getReadingTermAnalyzerName(lang)).execute().actionGet();

    final List<AnalyzeResponse.AnalyzeToken> readingTokenList = readingResponse.getTokens();
    final List<AnalyzeResponse.AnalyzeToken> termTokenList = termResponse.getTokens();

    final StringBuilder readingBuf = new StringBuilder(text.length());
    int offset = 0;
    for (int i = 0; i < readingTokenList.size(); i++) {
        final String term = termTokenList.get(i).getTerm();
        String reading = readingTokenList.get(i).getTerm();
        if (Strings.isNullOrEmpty(reading)) {
            reading = term;
        }
        reading = transliterator.transliterate(reading);

        final int pos = text.substring(offset).indexOf(term);
        if (pos > 0) {
            final String tmp = text.substring(offset, offset + pos);
            readingBuf.append(transliterator.transliterate(tmp));
            offset += pos;
        } else if (pos == -1) {
            continue;
        }

        readingBuf.append(reading);
        offset += term.length();
    }

    final List<String> list = new ArrayList<>(1);
    if (readingBuf.length() > 0) {
        list.add(readingBuf.toString());
    }
    return list;
}
 
開發者ID:codelibs,項目名稱:fess-suggest,代碼行數:43,代碼來源:AnalyzerConverter.java


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