Lucene查询无法正常工作

时间:2015-03-11 05:36:30

标签: java lucene

我正在使用Apache Lucene 5.0.0并使用QueryParser遇到问题。我试图创建一个Query但是我得到了一个ParseException。

以下是我的代码:

import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.queryparser.classic.ParseException;
import org.apache.lucene.queryparser.classic.QueryParser;

public class QueryTest {
    public static void main(String[] args) {
        QueryParser parser = new QueryParser("field", new StandardAnalyzer());
        try {
            parser.Query("query");
        } catch (ParseException e) {
            e.printStackTrace();
        }
    }
}

这是我得到的例外:

org.apache.lucene.queryparser.classic.ParseException: Encountered "<EOF>" at line 1, column 0.
Was expecting one of:
    <NOT> ...
    "+" ...
    "-" ...
    <BAREOPER> ...
    "(" ...
    "*" ...
    <QUOTED> ...
    <TERM> ...
    <PREFIXTERM> ...
    <WILDTERM> ...
    <REGEXPTERM> ...
    "[" ...
    "{" ...
    <NUMBER> ...
    <TERM> ...
    "*" ...

    at org.apache.lucene.queryparser.classic.QueryParser.generateParseException(QueryParser.java:698)
    at org.apache.lucene.queryparser.classic.QueryParser.jj_consume_token(QueryParser.java:580)
    at org.apache.lucene.queryparser.classic.QueryParser.Clause(QueryParser.java:265)
    at org.apache.lucene.queryparser.classic.QueryParser.Query(QueryParser.java:171)
    at QueryTest.main(QueryTest.java:9)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:483)
    at com.intellij.rt.execution.application.AppMain.main(AppMain.java:134)

如果有帮助,我已经包含以下jar文件:

  • 的lucene-分析器-共5.0.0.jar
  • lucene的核 - 5.0.0.jar
  • lucene的查询-5.0.0.jar
  • 的lucene-的QueryParser-5.0.0.jar
  • lucene的沙箱-5.0.0.jar

我不知道为什么抛出这个异常以及如何解决它。在线示例相似,但似乎对他们来说很好。

谢谢。

2 个答案:

答案 0 :(得分:1)

我认为你只是使用了错误的方法,你要做的是:

    QueryParser parser = new QueryParser("field", new StandardAnalyzer());
    try {
        Query query = parser.parse("query"); // changed this line
    } catch (ParseException e) {
        e.printStackTrace();
    }

答案 1 :(得分:0)

根据文件:

查询字符串的语法如下:  Query是一系列子句。  条款可以作为前缀:  

     
  • 加号(+)或减号(-)符号,表示  该条款分别是必需的或禁止的;要么  
  • 一个后跟冒号的术语,表示要搜索的字段。  这使得人们可以构建搜索多个字段的查询。  

条款可以是:  

     
  • 一个术语,表示包含该术语的所有文件;要么  
  • 嵌套查询,括在括号中。请注意,这可能会被使用  使用+ / -前缀来要求任何一组  条款。  

因此,在BNF中,查询语法是:  

   Query  ::= ( Clause )*
   Clause ::= ["+", "-"] [<TERM> ":"] ( <TERM> | "(" Query ")" )
 

有关详细信息,请查看此处 - http://lucene.apache.org/core/5_0_0/queryparser/org/apache/lucene/queryparser/classic/QueryParser.html

要特别解决您的问题,可能需要解析&#34;字段:查询&#34;字符串作为查询