14

当我尝试在 Lucene 中搜索诸如“解决方法/修复”之类的内容时,它会引发此错误:

org.apache.lucene.queryparser.classic.ParseException: Cannot parse 'workaround/fix': Lexical error at line 1, column 15.  Encountered: <EOF> after : "/fix"
    at org.apache.lucene.queryparser.classic.QueryParserBase.parse(QueryParserBase.java:131)
    at pi.lucengine.LucIndex.main(LucIndex.java:112)
Caused by: org.apache.lucene.queryparser.classic.TokenMgrError: Lexical error at line 1, column 15.  Encountered: <EOF> after : "/fix"
    at org.apache.lucene.queryparser.classic.QueryParserTokenManager.getNextToken(QueryParserTokenManager.java:1133)
    at org.apache.lucene.queryparser.classic.QueryParser.jj_scan_token(QueryParser.java:599)
    at org.apache.lucene.queryparser.classic.QueryParser.jj_3R_2(QueryParser.java:482)
    at org.apache.lucene.queryparser.classic.QueryParser.jj_3_1(QueryParser.java:489)
    at org.apache.lucene.queryparser.classic.QueryParser.jj_2_1(QueryParser.java:475)
    at org.apache.lucene.queryparser.classic.QueryParser.Clause(QueryParser.java:226)
    at org.apache.lucene.queryparser.classic.QueryParser.Query(QueryParser.java:181)
    at org.apache.lucene.queryparser.classic.QueryParser.TopLevelQuery(QueryParser.java:170)
    at org.apache.lucene.queryparser.classic.QueryParserBase.parse(QueryParserBase.java:121)

这是我的第 111 和 112 行:

QueryParser parser = new QueryParser(Version.LUCENE_43, field, analyzer);
Query query = parser.parse(newLine);

我需要做什么才能让它解析“/”?

4

3 回答 3

21

查询解析器将斜杠解释为开始/结束或正则表达式查询(从 4.0 开始,请参阅此处的文档)。

因此,要将斜杠合并到查询中,您需要通过在它们之前添加反斜杠 ( ) 来转义\它们。

您可以使用 处理转义QueryParser.escape(String)

于 2013-07-23T00:06:48.253 回答
3

在弹性搜索 kibana 仪表板发出的 lucene 查询中使用“/”时,我遇到了类似的问题。如文档中所示,我正在转义“/”字符,但仍未取得任何成功。我认为这与此处报告的模板错误有关:https ://github.com/elastic/kibana/issues/789 。还不确定,当我们更新 logstash 组件时会更新

于 2015-03-13T00:01:21.167 回答
1

我有一个案例,当使用带有通配符的正斜杠时,即使逃脱它也不会返回任何结果:

+(*16/17*)
+(*16\/17*)

解决方案是添加双引号:

+("*16/17*")
+("*16\/17*")
于 2017-08-28T13:10:29.523 回答