我正在使用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文件:
我不知道为什么会抛出此异常以及如何解决它。网上的例子很相似,但似乎对他们很有用。
谢谢你。
根据文件:
查询字符串的语法如下:查询是一系列子句。一个从句的前缀可以是:
)或减号(-
),分别表示要求或禁止该条款;或条款可以是:
/-
前缀一起使用,以要求任何一组术语
因此,在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”字符串解析为一个查询
我认为你只是使用了错误的方法,你试图做的是:
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类型中我的自定义分类中的数组。 和根本不起作用,我想不出原因。