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


Java MultiFieldQueryParser類代碼示例

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


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

示例1: searchIndex

import org.apache.lucene.queryParser.MultiFieldQueryParser; //導入依賴的package包/類
/**
 * 查詢索引
 * 
 * @param keywords
 * @return
 * @throws Exception
 */
public List<Document> searchIndex(Integer typeId, String keywords) throws Exception {
    // 1.init searcher
    Analyzer analyzer = new PaodingAnalyzer();
    IndexReader reader = IndexReader.open(typeId == appConfig.getGameTypeId() ? appConfig.getGameIndexDir()
            : appConfig.getSoftIndexDir());
    BooleanClause.Occur[] flags = new BooleanClause.Occur[] { BooleanClause.Occur.SHOULD,
            BooleanClause.Occur.SHOULD };
    Query query = MultiFieldQueryParser.parse(keywords, appConfig.getQueryFields(), flags, analyzer);
    query = query.rewrite(reader);

    // 2.search
    List<Document> docs = new ArrayList<Document>();
    Hits hits = (typeId == appConfig.getGameTypeId() ? gameSearcher.search(query, Sort.RELEVANCE) : softSearcher
            .search(query, Sort.RELEVANCE));// searcher.search(query,
                                            // Sort.RELEVANCE);
    for (int i = 0; i < hits.length(); i++) {
        docs.add(hits.doc(i));
    }

    // 3.return
    reader.close();
    return docs;
}
 
開發者ID:zhaoxi1988,項目名稱:sjk,代碼行數:31,代碼來源:SearchServiceImpl.java

示例2: search

import org.apache.lucene.queryParser.MultiFieldQueryParser; //導入依賴的package包/類
public List<Document> search (String queryString, SearchScope luceneFields) throws Exception {
    // using stop analyzer in search
    Analyzer analyzer = new StopAnalyzer(Version.LUCENE_30,  new File(ApplicationConstants.STOP_WORD_FILE));
    
    String[] fields = getSupportedFileds(luceneFields);
    
    MultiFieldQueryParser parser = new MultiFieldQueryParser(Version.LUCENE_30, fields, analyzer);
    
    // scpaing special characters
    queryString = QueryParser.escape(queryString);
    
    Query query = parser.parse(queryString);
    TopDocs topDocs = searcher.search(query, MAX_RESULT);

    List<Document> documents = new ArrayList<Document>();
    for(ScoreDoc scoreDocs: topDocs.scoreDocs) {
        Document document = searcher.doc(scoreDocs.doc);
        documents.add(document);
    }
    
    return documents;
}
 
開發者ID:CoEIA,項目名稱:DEM,代碼行數:23,代碼來源:LuceneSearcher.java

示例3: skynetsearch

import org.apache.lucene.queryParser.MultiFieldQueryParser; //導入依賴的package包/類
public Hits skynetsearch(String query, String Field, String indexPath) {
    String indexfield = Field + ":";
    String querytext = indexfield + query.trim();
    Hits result = null;

    try {

        String[] search_fields = {Field};
        //String indexPath = StorageHandler.GetDocIndexPath();
        IndexSearcher searcher = new IndexSearcher(indexPath);
        KeywordAnalyzer analyzer = new KeywordAnalyzer();
        Query lucenequery = MultiFieldQueryParser.parse(query,
                search_fields, analyzer);
        // QueryParser queryparse = new QueryParser(query,analyzer);
        // Query lucenequery = queryparse.parse(querytext);
        result = searcher.search(lucenequery);

    } catch (IOException e) {
        e.printStackTrace();
    } catch (Exception ex) {
        System.out.println(ex + "");
    }

    return result;
}
 
開發者ID:mobilipia,項目名稱:Deskera-HRMS,代碼行數:26,代碼來源:SearchBean.java

示例4: skynetsearchMulti

import org.apache.lucene.queryParser.MultiFieldQueryParser; //導入依賴的package包/類
public Hits skynetsearchMulti(String query, String[] Field, String indexPath) {
    Hits result = null;
    try {
        IndexSearcher searcher = new IndexSearcher(indexPath);
        KeywordAnalyzer analyzer = new KeywordAnalyzer();
        MultiFieldQueryParser multiparser = new MultiFieldQueryParser(Field, analyzer);
        multiparser.setDefaultOperator(QueryParser.Operator.OR);
        Query lucenequery = multiparser.parse(query);
        result = searcher.search(lucenequery);
    } catch (IOException e) {
        e.printStackTrace();
    } catch (Exception ex) {
        System.out.println(ex + "");
    }

    return result;
}
 
開發者ID:mobilipia,項目名稱:Deskera-HRMS,代碼行數:18,代碼來源:SearchBean.java

示例5: createFullTextQuery

import org.apache.lucene.queryParser.MultiFieldQueryParser; //導入依賴的package包/類
private org.apache.lucene.search.Query createFullTextQuery(final String[] searchFields, final QueryFilter queryFilter,
    final String searchString)
{
  final MultiFieldQueryParser parser = new MultiFieldQueryParser(LUCENE_VERSION, searchFields, new ClassicAnalyzer(Version.LUCENE_31));
  parser.setAllowLeadingWildcard(true);
  org.apache.lucene.search.Query query = null;
  try {
    query = parser.parse(searchString);
  } catch (final org.apache.lucene.queryParser.ParseException ex) {
    final String errorMsg = "Lucene error message: "
        + ex.getMessage()
        + " (for "
        + this.getClass().getSimpleName()
        + ": "
        + searchString
        + ").";
    if (queryFilter != null) {
      queryFilter.setErrorMessage(errorMsg);
    }
    log.info(errorMsg);
    return null;
  }
  return query;
}
 
開發者ID:micromata,項目名稱:projectforge-webapp,代碼行數:25,代碼來源:BaseDao.java

示例6: getFullTextQueryForKeywordOnAllAnnotatedFields

import org.apache.lucene.queryParser.MultiFieldQueryParser; //導入依賴的package包/類
public FullTextQuery getFullTextQueryForKeywordOnAllAnnotatedFields(String keyword) throws ParseException {

    String[] indexedFields = findAllIndexedFields(entity);

    final QueryParser parser = new MultiFieldQueryParser(Version.LUCENE_35, indexedFields, analyzer);
    parser.setAllowLeadingWildcard(true);

    // Add wildcards when not already in search
    if (!(StringUtils.containsAny(keyword, new char[] { '*', '?', ':' }) || keyword.startsWith("\"") && keyword.endsWith("\""))) {
      keyword = "*" + keyword + "*";
    }

    Query luceneQuery = parser.parse(keyword);
    FullTextQuery fullTextQuery = getFullTextQuery(luceneQuery);
    return fullTextQuery;
  }
 
開發者ID:BandwidthOnDemand,項目名稱:bandwidth-on-demand,代碼行數:17,代碼來源:FullTextSearchContext.java

示例7: search

import org.apache.lucene.queryParser.MultiFieldQueryParser; //導入依賴的package包/類
public Hits search(String type, String qstr)
{
	
	String queryStr = "(" + qstr + ") OR ("+TStransformer.STtransform(qstr)+")";
	
	Hits hits = null;
	try{
		FSDirectory fsd = FSDirectory.getDirectory(QuickSearchConfig.getIndexDir() + "/" + type);
		//RAMDirectory ramd = new RAMDirectory(QuickSearchConfig.getIndexDir() + "/" + type);
		IndexSearcher indexSearcher = new IndexSearcher(fsd);
		Query query = MultiFieldQueryParser.parse(queryStr, fields, flags, analyzer);
		hits = indexSearcher.search(query);
	}catch(Exception ex){
		ex.printStackTrace();
	}
	return hits;
}
 
開發者ID:YinYanfei,項目名稱:CadalWorkspace,代碼行數:18,代碼來源:ConsoleSearch.java

示例8: testDefaultOperator

import org.apache.lucene.queryParser.MultiFieldQueryParser; //導入依賴的package包/類
public void testDefaultOperator() throws Exception {
  Query query = new MultiFieldQueryParser(Version.LUCENE_41,
                                          new String[]{"title", "subject"},
      new SimpleAnalyzer()).parse("development");

  Directory dir = TestUtil.getBookIndexDirectory();
  IndexSearcher searcher = new IndexSearcher(
                             dir,
                             true);
  TopDocs hits = searcher.search(query, 10);

  assertTrue(TestUtil.hitsIncludeTitle(
         searcher,
         hits,
         "Ant in Action"));

  assertTrue(TestUtil.hitsIncludeTitle(     //A
         searcher,                          //A
         hits,                              //A
         "Extreme Programming Explained")); //A
  searcher.close();
  dir.close();
}
 
開發者ID:xuzhikethinker,項目名稱:t4f-data,代碼行數:24,代碼來源:MultiFieldQueryParserTest.java

示例9: testSpecifiedOperator

import org.apache.lucene.queryParser.MultiFieldQueryParser; //導入依賴的package包/類
public void testSpecifiedOperator() throws Exception {
  Query query = MultiFieldQueryParser.parse(Version.LUCENE_41,
      "lucene",
      new String[]{"title", "subject"},
      new BooleanClause.Occur[]{BooleanClause.Occur.MUST,
                BooleanClause.Occur.MUST},
      new SimpleAnalyzer());

  Directory dir = TestUtil.getBookIndexDirectory();
  IndexSearcher searcher = new IndexSearcher(
                             dir,
                             true);
  TopDocs hits = searcher.search(query, 10);

  assertTrue(TestUtil.hitsIncludeTitle(
          searcher,
          hits,
          "Lucene in Action, Second Edition"));
  assertEquals("one and only one", 1, hits.scoreDocs.length);
  searcher.close();
  dir.close();
}
 
開發者ID:xuzhikethinker,項目名稱:t4f-data,代碼行數:23,代碼來源:MultiFieldQueryParserTest.java

示例10: IndexSearcher

import org.apache.lucene.queryParser.MultiFieldQueryParser; //導入依賴的package包/類
public IndexSearcher() {
    try {
        searcher = new org.apache.lucene.search.IndexSearcher(new ClasspathDirectory());
    } catch (IOException e) {
        e.printStackTrace();
    }
    analyzer = new StandardAnalyzer(Version.LUCENE_31);
    parser = new MultiFieldQueryParser(Version.LUCENE_31, new String[]{"name","description"}, analyzer);
}
 
開發者ID:jalian-systems,項目名稱:marathonv5,代碼行數:10,代碼來源:IndexSearcher.java

示例11: search

import org.apache.lucene.queryParser.MultiFieldQueryParser; //導入依賴的package包/類
/**
 * 檢索
 *
 * @param keyword
 */
public static void search(String keyword) throws Exception {

    IndexSearcher searcher = null;

    try {
        // 創建search
        searcher = getIndexSearcher();

        String[] fields = { "name", "author", "content" };
        QueryParser queryParser = new MultiFieldQueryParser(Version.LUCENE_35, fields,
            new StandardAnalyzer(Version.LUCENE_35));
        queryParser.setDefaultOperator(QueryParser.AND_OPERATOR);
        Query query = queryParser.parse(keyword);

        // 查詢
        TopDocs topDocs = searcher.search(query, MAX);

        ScoreDoc[] scoreDocs = topDocs.scoreDocs;
        logger.info("查詢到條數=" + scoreDocs.length);

        for (ScoreDoc scoreDoc : scoreDocs) {
            Document doc = searcher.doc(scoreDoc.doc);
            logger.info("doc信息:" + "docId=" + scoreDoc.doc + "id=" + doc.get("id") + "author="
                        + doc.get("author") + "name=" + doc.get("name") + "content="
                        + doc.get("content"));
        }

    } catch (Exception e) {
        logger.error("查詢失敗:" + e.getMessage());
        throw e;
    }
}
 
開發者ID:cycman,項目名稱:libooc,代碼行數:38,代碼來源:IndexUtil.java

示例12: multiFieldQuery

import org.apache.lucene.queryParser.MultiFieldQueryParser; //導入依賴的package包/類
/**
     * 多條搜索
     * @param fields
     * @param value
     * @throws Exception
     */
    public static void multiFieldQuery( String[] fields, String value,List<Document>docs) throws Exception {
        try {

        	
            // 創建search
            IndexSearcher searcher = getIndexSearcher();


            QueryParser queryParser = new MultiFieldQueryParser(Version.LUCENE_35, fields,
                    new StandardAnalyzer(Version.LUCENE_35));

            queryParser.setDefaultOperator(QueryParser.AND_OPERATOR);
            Query query = queryParser.parse(value);

            // 查詢
            
            TopDocs topDocs = searcher.search(query, 1000);

            ScoreDoc[] scoreDocs = topDocs.scoreDocs;
            logger.info("查詢到條數=" + scoreDocs.length);

            for (ScoreDoc scoreDoc : scoreDocs) {
                Document doc = searcher.doc(scoreDoc.doc);
//                logger.info("doc信息:" + " docId=" + scoreDoc.doc + " id=" + doc.get("id") + " author="
//                        + doc.get("author") + " name=" + doc.get("name") + " content="
//                        + doc.get("content"));
                docs.add(doc);
            }
        } catch (Exception e) {
            logger.error("termQuery查詢失敗");
            throw e;
        }
    }
 
開發者ID:cycman,項目名稱:libooc,代碼行數:40,代碼來源:SearchUtil.java

示例13: loadModel

import org.apache.lucene.queryParser.MultiFieldQueryParser; //導入依賴的package包/類
@Override
public void loadModel(String modelPath) throws IOException {
	docsSearcher = new IndexSearcher((new File(modelPath, "docs"))
			.getAbsolutePath());
	String[] fields = { "doc_id", "content", "user_id", "tag" };
	queryParser = new MultiFieldQueryParser(fields,
			new WhitespaceAnalyzer());
}
 
開發者ID:thunlp,項目名稱:THUTag,代碼行數:9,代碼來源:ExpandRankKE.java

示例14: search

import org.apache.lucene.queryParser.MultiFieldQueryParser; //導入依賴的package包/類
@SuppressWarnings("unchecked")
@DataProvider
public List<SearchResult> search(String searchText) throws Exception {
	FullTextSession fullTextSession = Search.getFullTextSession(exampleDao
			.getSession());

	if (!indexRebuilded) {
		indexRebuilded = true;
		fullTextSession.createIndexer().startAndWait();
	}

	MultiFieldQueryParser parser = new MultiFieldQueryParser(
			Version.LUCENE_31, new String[] { "label", "tags", "url",
					"summary" }, new StandardAnalyzer(Version.LUCENE_31));
	org.apache.lucene.search.Query luceneQuery = parser.parse(searchText);
	FullTextQuery query = fullTextSession.createFullTextQuery(luceneQuery,
			Example.class);
	query.setFirstResult(0);
	query.setMaxResults(100);

	List<SearchResult> searchResults = new ArrayList<SearchResult>();
	for (Example example : (List<Example>) query.list()) {
		SearchResult searchResult = new SearchResult();
		PropertyUtils.copyProperties(searchResult, example);
		searchResults.add(searchResult);
	}
	return searchResults;
}
 
開發者ID:toulezu,項目名稱:play,代碼行數:29,代碼來源:Main.java

示例15: findByKeywords

import org.apache.lucene.queryParser.MultiFieldQueryParser; //導入依賴的package包/類
@SuppressWarnings("unchecked")
@Override
public List<User> findByKeywords(String keywords, SearchType searchType) {
    MultiFieldQueryParser parser = new MultiFieldQueryParser(
            Version.LUCENE_31,
            new String[] { "names", USERNAME_FIELD, EMAIL_FIELD },
            new StandardAnalyzer(Version.LUCENE_31));

    keywords = escapeKeywords(keywords);

    if (searchType == SearchType.START) {
        keywords += "*";
    }
    if (searchType == SearchType.FUZZY) {
        keywords += "~";
    }
    if (searchType == SearchType.FULL) {
        String[] parts = keywords.split(" ");
        StringBuilder sb = new StringBuilder();
        for (String part : parts) {
            sb.append(part + "* ");
        }
        keywords = sb.toString();
    }

    Query query;

    try {
        query = parser.parse(keywords);
    } catch (ParseException e) {
        log.warn("Problem parsing query", e);
        return Collections.emptyList();
    }

    FullTextQuery ftq = getFullTextEntityManager().createFullTextQuery(
            query, User.class);
    ftq.setMaxResults(commonPageSize);

    return ftq.getResultList();
}
 
開發者ID:Glamdring,項目名稱:welshare,代碼行數:41,代碼來源:UserDaoJpa.java


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