0.文档名字:(根据名字索引查询文档)…
一.查询理论 创建查询:构建一个包含了文档域和语汇单元的文档查询对象.(例:fileName:lucene) 查询过程:根据查询对象的条件,在索引中找出相应的term,然后根据term找到对应的文档id列表. 二.代码分析 实现代码 /** * Lucene入门 * 查询索引 */ public class QueryIndex { /** * 查询索引 * 第一步:创建一个Directory对象,指定索引库的位置 * 第二步:创建一个IndexReader(索引读取)对象,需要指定Direct…
影视剧字幕聊天语料库特点,把影视剧说话内容一句一句以回车换行罗列三千多万条中国话,相邻第二句很可能是第一句最好回答.一个问句有很多种回答,可以根据相关程度以及历史聊天记录所有回答排序,找到最优,是一个搜索排序过程. lucene+ik.lucene开源免费搜索引擎库,java语言开发.ik IKAnalyzer,开源中文切词工具.语料库切词建索引,文本搜索做文本相关性检索,把下一句取出作答案候选集,答案排序,问题分析. 建索引.eclipse创建maven工程,maven自动生成pom.xml文…
QueryParser(单域查询) QueryParser子类对单个域查询时创建查询query,构造方法中需要传入Lucene版本号,检索域名和分词器. QueryParser parser = new QueryParser(Version.LUCENE_43, field, analyzer);// 查询字符串 Query query = parser.parse("key"); MultiFieldQueryParser(多域查询) MultiFieldQueryParser p…
目录 1 Query对象的创建(方式一): 使用子类对象 1.1 常用的Query子类对象 1.2 常用的Query子类对象使用 1.2.1 使用TermQuery 1.2.2 使用NumericRangeQuery 1.2.3 使用BooleanQuery 2 Query对象的创建(方式二): 使用QueryParser 2.1 QueryParse表达式语法 2.2 使用QueryParser Lucene是使用Query对象执行查询的, 由Query对象生成查询的语法. 如bookName…
1. Lucene的下载 Lucene是开发全文检索功能的工具包,从官网下载Lucene4.10.3并解压. 官网:http://lucene.apache.org/ 版本:lucene7.7.0 (学习上没必要最新的,因为企业中也不会升级太快) Jdk要求:1.7以上 2.使用的jar包 核心包 其他:  3. 创建索引库 (1) 实现步骤 (程序的编写步骤与之前分析的理论步骤是颠倒过来的) 第一步:创建java工程,并导入jar包 第二步:创建一个indexwriter对象(创建索引) 1.…
一. Lucene索引库查询 对要搜索的信息创建Query查询对象,Lucene会根据Query查询对象生成最终的查询语法,类似关系数据库Sql语法一样Lucene也有自己的查询语法,比如:“name:lucene”表示查询Field的name为“lucene”的文档信息. 可通过两种方法创建查询对象: 1)使用Lucene提供Query子类 2)使用QueryParse解析查询表达式 二. TermQuery TermQuery,通过项查询,TermQuery不使用分析器所以建议匹配不分词的F…
Query子类 TermQuery:根据域和关键词进行搜索 /** * termQuery根据域和关键词进行搜索 */ @Test public void termQuery() throws IOException { //1.创建Directory对象,指定索引库位置 Directory directory = FSDirectory.open(new File("D:\\Luene资料\\Index").toPath()); //2.创建IndexReader对象,读取索引库内容…
Query的子类查询 PS:这是通用代码,下面的子类查询调用到的时候就不再写这部分的具体的实现过程了 /** * 构造IndexSearcher对象 * * @return * @throws Exception */ private IndexSearcher getIndexSearcher() throws Exception { /*创建一个Directory对象,指定索引库的位置*/ Directory directory = FSDirectory.open(new File("E:…