gpt4 book ai didi

lucene.net - 为什么这个 Lucene 查询是 "contains"而不是 "startsWith"?

转载 作者:行者123 更新时间:2023-12-04 19:24:30 24 4
gpt4 key购买 nike

string q = "m";
Query query = new QueryParser("company", new StandardAnalyzer()).Parse(q+"*");

将导致查询为 prefixQuery :company:a*

我仍然会得到像“Fleet Africa”这样的结果,很明显,A 不在开始时,因此给了我不想要的结果。
Query query = new TermQuery(new Term("company", q+"*"));

将导致查询成为 termQuery :company:a* 并且不返回任何结果。可能是因为它将查询解释为完全匹配,而我的值都不是“a*”文字。
Query query = new WildcardQuery(new Term("company", q+"*"));

将返回与前缀查询相同的结果;

我究竟做错了什么?

最佳答案

StandardAnalyzer 会将“Fleet Africa”标记为“fleet”和“africa”。您的 a* 搜索将匹配后面的术语。

如果您想将“Fleet Africa”视为一个术语,请使用不会在空格上拆分字符串的分析器。 KeywordAnalyzer 是一个示例,但您可能仍希望将数据小写,以便查询不区分大小写。

关于lucene.net - 为什么这个 Lucene 查询是 "contains"而不是 "startsWith"?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/605899/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com