当前位置: 首页 > 知识库问答 >
问题:

Lucene查询不工作

卜昂熙
2023-03-14

我正在使用ApacheLucene5.0。0并在使用QueryParser时遇到问题。我试图创建一个查询,但得到一个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-analyzers-common-5.0.0.jar
  • lucene-core-5.0.0.jar
  • lucene-queries-5.0.0.jar
  • lucene-queryparser-5.0.0.jar
  • lucene-sandbox-5.0.0.jar

我不知道为什么会抛出此异常以及如何解决它。网上的例子很相似,但似乎对他们很有用。

谢谢你。

共有2个答案

东方夕
2023-03-14

根据文件

查询字符串的语法如下:查询是一系列子句。一个从句的前缀可以是:

  • 加号()或减号(-),分别表示要求或禁止该条款;或
  • 后跟冒号的术语,表示要搜索的字段。这使人们能够构造搜索多个字段的查询

条款可以是:

  • 一个术语,表示包含该术语的所有文件;或
  • 嵌套查询,用括号括起来。请注意,这可能与/-前缀一起使用,以要求任何一组术语

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

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

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

为了特别解决您的问题,可能需要将“field:Query”字符串解析为一个查询

殳凯捷
2023-03-14

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

    QueryParser parser = new QueryParser("field", new StandardAnalyzer());
    try {
        Query query = parser.parse("query"); // changed this line
    } catch (ParseException e) {
        e.printStackTrace();
    }
 类似资料:
  • 我对Lucene的不同查询对象进行了一些试验,并试图理解为什么在使用WhitespaceAnaylzer进行索引时,前缀查询与任何文档都不匹配。考虑以下测试代码: 如果我用StandardAnalyzer替换WhitespaceAnaylzer,测试就会通过。我使用Luke检查索引内容,但在索引过程中Lucene存储值的方式上找不到任何差异。谁能澄清一下出了什么问题吗?

  • 我的任务是使用lucene在我们的产品表中搜索。我已经创建了一个索引,正在使用带有多个字段的QueryParser进行搜索,但结果不是我所需要的。我有一个存储为LM10的产品,但如果搜索词是LM 10,我希望能够找到它,但如果搜索词是Fred LM10或Fred LM 10,它也必须能够匹配。你知道我如何在Lucene做到这一点吗。 提前谢谢

  • Lucene查询语言 ElasticSearch提供的一些查询方式(query types)能够被Lucene的查询解析器(query parser)语法所支持。由于这个原因,我们来深入学习Lucene查询语言,了解其庐山真面目吧。 基础语法 用户使用Lucene进行查询操作时,输入的查询语句会被分解成一个或者多个Term以及逻辑运算符号。一个Term,在Lucene中可以是一个词,也可以是一个短

  • 我很难理解如何处理lucene中的特殊角色 我的分析器没有停止字,因此不会删除特殊字符: 比我创建文档要多: 查询标签:brüder\-g工作正常,但是模糊查询标签:brüder\-g~不返回任何内容。当街道名称为Eselgasse查询标签时:Esel~将正常工作。 我使用Lucene 5.3.1 谢谢你的帮助!

  • 在这种情况下,我没有得到任何结果。我试图弄清楚是否存在“NumericTermQuery”,但找不到。我可以做一些棘手的事情(为我正在搜索的术语做一个范围查询),但我不喜欢这个解决方案。 谢谢你!

  • 我的查询没有使用参数对我的帖子进行排序。 一点背景: 我在foreach语句中,该语句循环遍历“category”id的自定义分类法。在该foreach语句中,我试图调用一个新的WP_查询,从该foreach循环的每个“类别”获取帖子。我的args数组如下所示: 和都是此post\u类型中我的自定义分类中的数组。 和根本不起作用,我想不出原因。