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


Java ParseException類代碼示例

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


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

示例1: getFieldQuery

import org.apache.lucene.queryParser.ParseException; //導入依賴的package包/類
/**
 *  Gets the fieldQuery attribute of the FieldExpansionQueryParser object
 *
 * @param  field               The field being processed
 * @param  queryText           The text in the field
 * @return                     The fieldQuery value
 * @exception  ParseException  If error
 */
protected Query getFieldQuery(String field, String queryText)
	 throws ParseException {

	// prtln("getFieldQuery( field: '" + field + "', queryText: '" + queryText + "'");

	// If a VirtualSearchFieldMapper is available and has a mapping for this field, use it:
	if (virtualSearchFieldMapper != null) {
		Query q = virtualSearchFieldMapper.getQuery(field, queryText);
		if (q != null)
			return q;
	}

	// Extract and store the terms in the default field once only - used for boosting
	if (field.equals(expansionFields[0])) {
		String[] tmp = queryText.split("\\s+");
		for (int i = 0; i < tmp.length; i++)
			terms.add(tmp[i]);
	}

	// Then perform the normal field query
	return super.getFieldQuery(field, queryText);
}
 
開發者ID:NCAR,項目名稱:joai-project,代碼行數:31,代碼來源:FieldExpansionQueryParser.java

示例2: getDefaultOperator

import org.apache.lucene.queryParser.ParseException; //導入依賴的package包/類
public Operator getDefaultOperator() throws ParseException
{
	Operator o;

	if( this.defaultOperator.equalsIgnoreCase("and") )
	{
		o = Operator.AND;
	}
	else if( this.defaultOperator.equalsIgnoreCase("OR") )
	{
		o = Operator.OR;
	}
	else
	{
		throw new ParseException("Invalid Default Operator (AND/OR)");
	}

	return o;
}
 
開發者ID:equella,項目名稱:Equella,代碼行數:20,代碼來源:ItemIndex.java

示例3: processArgument

import org.apache.lucene.queryParser.ParseException; //導入依賴的package包/類
@Override
protected boolean processArgument(String arg) throws CLIOException {
	try {
		Analyzer analyzer = PubMedIndexUtils.getGlobalAnalyzer();
		QueryParser parser = new QueryParser(PubMedIndexUtils.LUCENE_VERSION, PubMedIndexField.ABSTRACT.fieldName, analyzer);
		parser.setDefaultOperator(QueryParser.AND_OPERATOR);
		parser.setLowercaseExpandedTerms(false);
		PubMedIndexUtils.log("parsing query: %s", arg);
		Query q = parser.parse(arg);
		PubMedIndexUtils.log("query: %s", q);
		addClause(q);
		return false;
	}
	catch (ParseException e) {
		throw new CLIOException(e);
	}
}
 
開發者ID:Bibliome,項目名稱:bibliome-java-utils,代碼行數:18,代碼來源:PubMedIndexSearcher.java

示例4: search

import org.apache.lucene.queryParser.ParseException; //導入依賴的package包/類
public Map<String, Integer> search(String word, String field, int maxSearch) {
    if (indexSearcher == null) {
        initialize(index);
    }
    Map<String, Integer> verbFreqs = new HashMap<>();
    QueryParser queryParser = new QueryParser(Version.LUCENE_36, field, analyzer);
    try {
        Query query = queryParser.parse(word);
        TopDocs topDocs = indexSearcher.search(query, maxSearch);
        ScoreDoc[] doc = topDocs.scoreDocs;
        for (int i = 0; i < maxSearch && i < doc.length; ++i) {
            int documentId = doc[i].doc;
            Document document = indexSearcher.doc(documentId);
            String verb = document.get(VERB);
            String frequency = document.get(FREQ);
            verbFreqs.put(verb, Integer.parseInt(frequency));
        }
    } catch (ParseException | IOException e) {
        log.warn("Error searching Lucene index.", e);
    }
    return verbFreqs;
}
 
開發者ID:clearwsd,項目名稱:clearwsd,代碼行數:23,代碼來源:LuceneWrapper.java

示例5: select

import org.apache.lucene.queryParser.ParseException; //導入依賴的package包/類
/**
  * Executes a select query.
  * @param query The Lucene query
  * @return An array of record IDs; an empty array if an error occured
* @throws IOException 
  */
 public int[] select(String query, String sortPrefix)  throws ParseException{
   try {
     WhitespaceAnalyzer sa= new WhitespaceAnalyzer();
     BooleanQuery.setMaxClauseCount(20000);//zbog heap-a
     QueryParser p = new QueryParser("KW", sa);
     p.setDefaultOperator(QueryParser.Operator.AND); //default operator je AND a ne OR kao sto je inace inicijalno
     Query q = p.parse(query);
     return select(q, sortPrefix);
   } catch (Exception ex) {
   	if (ex instanceof ParseException )
   		throw (ParseException)ex;
     log.warn(ex);
     return new int[0];
   }
 }
 
開發者ID:unsftn,項目名稱:bisis-v4,代碼行數:22,代碼來源:Retriever.java

示例6: search

import org.apache.lucene.queryParser.ParseException; //導入依賴的package包/類
/**
 * Search in documents
 */
private static void search(Directory index, Analyzer analyzer, String str) throws ParseException, CorruptIndexException,
		IOException {
	IndexReader reader = IndexReader.open(index);
	IndexSearcher searcher = new IndexSearcher(reader);
	TopScoreDocCollector collector = TopScoreDocCollector.create(NUM_HITS, true);
	//Query q = new QueryParser(Config.LUCENE_VERSION, DOC_FIELD, analyzer).parse(str);
	Query q = new WildcardQuery(new Term(DOC_FIELD, str));
	System.out.println("Query: " + q);

	searcher.search(q, collector);
	ScoreDoc[] hits = collector.topDocs().scoreDocs;

	System.out.println("Found " + hits.length + " hits.");

	for (int i = 0; i < hits.length; ++i) {
		int docId = hits[i].doc;
		Document d = searcher.doc(docId);
		System.out.println((i + 1) + ". " + d.get(DOC_FIELD));
	}

	searcher.close();
}
 
開發者ID:openkm,項目名稱:document-management-system,代碼行數:26,代碼來源:SearchDemo.java

示例7: makeQueryFromKeywords

import org.apache.lucene.queryParser.ParseException; //導入依賴的package包/類
public Query makeQueryFromKeywords(List<WeightString> keywords, int n)
throws ParseException {
  StringBuilder queryString = new StringBuilder();
  for (int i = 0; i < n && i < keywords.size(); i++) {
    if (i > 0)
      queryString.append(' ');
    queryString.append(keywords.get(i).text);
    queryString.append('^');
    queryString.append(String.format("%.2f",
        Math.log(keywords.get(i).weight + 1)));
  }
  if (queryString.length() == 0)
    queryString.append("a");
  Query q = queryParser.parse(queryString.toString());
  return q;
}
 
開發者ID:thunlp,項目名稱:THUTag,代碼行數:17,代碼來源:KnnTagSuggest.java

示例8: makeQueryFromKeywords

import org.apache.lucene.queryParser.ParseException; //導入依賴的package包/類
public Query makeQueryFromKeywords(List<WeightString> keywords, int n)
		throws ParseException {
	StringBuilder queryString = new StringBuilder();
	for (int i = 0; i < n && i < keywords.size(); i++) {
		if (i > 0)
			queryString.append(' ');
		queryString.append(keywords.get(i).text);
		queryString.append('^');
		queryString.append(String.format("%.2f", Math
				.log(keywords.get(i).weight + 1)));
	}
	if (queryString.length() == 0)
		queryString.append("a");
	Query q = queryParser.parse(queryString.toString());
	return q;
}
 
開發者ID:thunlp,項目名稱:THUTag,代碼行數:17,代碼來源:ExpandRankKE.java

示例9: search

import org.apache.lucene.queryParser.ParseException; //導入依賴的package包/類
public static void search(String indexDir, String q)
	throws IOException, ParseException {
	
	Directory dir = FSDirectory.open(new File(indexDir));
	IndexSearcher is = new IndexSearcher(dir);
	
	QueryParser parser = new QueryParser(Version.LUCENE_30, "contents", 
			new StandardAnalyzer(Version.LUCENE_30));
	Query query = parser.parse(q);
	
	long start = System.currentTimeMillis();
	TopDocs hits = is.search(query, 10);
	long end = System.currentTimeMillis();
	
	System.out.println(" document(s) (in " + (end - start) + " milliseconds) that matched query '" +
				q + "':" + ("Found " + hits.totalHits));
	
	for(ScoreDoc scoreDoc : hits.scoreDocs) {
		Document doc = is.doc(scoreDoc.doc);
		System.out.println(doc.get("fullpath"));
	}
	
	is.close();
}
 
開發者ID:tensorchen,項目名稱:rrs,代碼行數:25,代碼來源:Searcher.java

示例10: jj_consume_token

import org.apache.lucene.queryParser.ParseException; //導入依賴的package包/類
private Token jj_consume_token(int kind) throws ParseException {
	Token oldToken;
	if ((oldToken = token).next != null)
		token = token.next;
	else
		token = token.next = token_source.getNextToken();
	jj_ntk = -1;
	if (token.kind == kind) {
		jj_gen++;
		if (++jj_gc > 100) {
			jj_gc = 0;
			for (int i = 0; i < jj_2_rtns.length; i++) {
				JJCalls c = jj_2_rtns[i];
				while (c != null) {
					if (c.gen < jj_gen)
						c.first = null;
					c = c.next;
				}
			}
		}
		return token;
	}
	token = oldToken;
	jj_kind = kind;
	throw generateParseException();
}
 
開發者ID:kuzavas,項目名稱:ephesoft,代碼行數:27,代碼來源:QueryParser.java

示例11: listVertices

import org.apache.lucene.queryParser.ParseException; //導入依賴的package包/類
public List<Integer> listVertices(String expression) {
    try {
        List<Integer> results = new ArrayList<>();
        IndexReader reader = IndexReader.open(vertexIndex);
        IndexSearcher searcher = new IndexSearcher(reader);
        ScoreDoc[] hits = searcher.search(queryParser.parse(expression), MAX_QUERY_HITS).scoreDocs;

        for (int i = 0; i < hits.length; ++i) {
            int docId = hits[i].doc;
            Document foundDoc = searcher.doc(docId);
            results.add(Integer.parseInt(foundDoc.get(ID_STRING)));
        }

        searcher.close();
        reader.close();
        return results;
    } catch (IOException | ParseException | NumberFormatException exception) {
        logger.log(Level.WARNING, "Error while listing vertices. Returning empty array.", exception);
        return new ArrayList<>();
    }
}
 
開發者ID:ashish-gehani,項目名稱:SPADE,代碼行數:22,代碼來源:Graph.java

示例12: createIndex

import org.apache.lucene.queryParser.ParseException; //導入依賴的package包/類
@Transactional(readOnly = true)
public Integer createIndex(Integer siteId, Integer channelId,
		Date startDate, Date endDate, Integer startId, Integer max,
		Directory dir) throws IOException, ParseException {
	boolean exist = IndexReader.indexExists(dir);
	IndexWriter writer = new IndexWriter(dir, new StandardAnalyzer(
			Version.LUCENE_30), !exist, IndexWriter.MaxFieldLength.LIMITED);
	try {
		if (exist) {
			LuceneContent.delete(siteId, channelId, startDate, endDate,
					writer);
		}
		Integer lastId = luceneContentDao.index(writer, siteId, channelId,
				startDate, endDate, startId, max);
		writer.optimize();
		return lastId;
	} finally {
		writer.close();
	}
}
 
開發者ID:huanzhou,項目名稱:jeecms6,代碼行數:21,代碼來源:LuceneContentSvcImpl.java

示例13: searchPage

import org.apache.lucene.queryParser.ParseException; //導入依賴的package包/類
@Transactional(readOnly = true)
public Pagination searchPage(Directory dir, String queryString,String category,String workplace,
		Integer siteId, Integer channelId, Date startDate, Date endDate,
		int pageNo, int pageSize) throws CorruptIndexException,
		IOException, ParseException {
	Searcher searcher = new IndexSearcher(dir);
	try {
		Analyzer analyzer = new StandardAnalyzer(Version.LUCENE_30);
		Query query = LuceneContent.createQuery(queryString,category,workplace, siteId,
				channelId, startDate, endDate, analyzer);
		TopDocs docs = searcher.search(query, pageNo * pageSize);
		Pagination p = LuceneContent.getResultPage(searcher, docs, pageNo,
				pageSize);
		List<?> ids = p.getList();
		List<Content> contents = new ArrayList<Content>(ids.size());
		for (Object id : ids) {
			contents.add(contentMng.findById((Integer) id));
		}
		p.setList(contents);
		return p;
	} finally {
		searcher.close();
	}
}
 
開發者ID:huanzhou,項目名稱:jeecms6,代碼行數:25,代碼來源:LuceneContentSvcImpl.java

示例14: buildFilter

import org.apache.lucene.queryParser.ParseException; //導入依賴的package包/類
@org.hibernate.search.annotations.Factory
public Filter buildFilter(){
	QueryParser qp = new QueryParser(Version.LUCENE_CURRENT,field, analyzer);
	Query q;
	try {
		if(allowLuceneSyntax)
			q = qp.parse(value);
		else
			q = qp.parse(QueryParser.escape(value));
	} catch (ParseException e) {
		org.webdsl.logging.Logger.error("Error while parsing query in field filter: ");
		org.webdsl.logging.Logger.error("EXCEPTION",e);
		q = new TermQuery(new Term(field, value));
	}
	Filter filter = new QueryWrapperFilter(q);
	filter = new CachingWrapperFilter( filter );
	return filter;
}
 
開發者ID:webdsl,項目名稱:webdsl,代碼行數:19,代碼來源:FieldConstraintFilter.java

示例15: getCollectionFilters

import org.apache.lucene.queryParser.ParseException; //導入依賴的package包/類
/**
 * Set up the filters for collections - this is for searching within collections.
 * 
 * @param collection - to search within
 * @return - created filter
 * @throws ParseException
 */
private List<Filter> getCollectionFilters(InstitutionalCollection collection) throws ParseException
{
	List<Filter> filters = new LinkedList<Filter>();
	
       //isolate the collection root
	Term t = new Term("collection_root_id", NumericUtils.longToPrefixCoded(collection.getTreeRoot().getId()));
	Query subQuery = new TermQuery( t );
	filters.add(new QueryWrapperFilter(subQuery));
	
	
	//isolate the range of children
	subQuery = NumericRangeQuery.newLongRange("collection_left_value", collection.getLeftValue(), collection.getRightValue(), true, true);
	filters.add(new QueryWrapperFilter(subQuery));
    return filters;
}
 
開發者ID:nate-rcl,項目名稱:irplus,代碼行數:23,代碼來源:DefaultInstitutionalItemSearchService.java


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