Lucene02--入门程序
Lucene02--入门程序
开发准备:
Win10
IDEA
JDK1.8
1、新建一个普通的maven工程
1.1 添加依赖
<dependencies>
<!-- Junit单元测试 -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
<!-- lucene核心库 -->
<dependency>
<groupId>org.apache.lucene</groupId>
<artifactId>lucene-core</artifactId>
<version>7.4.0</version>
</dependency>
<!-- Lucene的查询解析器 -->
<dependency>
<groupId>org.apache.lucene</groupId>
<artifactId>lucene-queryparser</artifactId>
<version>7.4.0</version>
</dependency>
<!-- lucene的默认分词器库 -->
<dependency>
<groupId>org.apache.lucene</groupId>
<artifactId>lucene-analyzers-common</artifactId>
<version>7.4.0</version>
</dependency>
<!-- lucene的高亮显示 -->
<dependency>
<groupId>org.apache.lucene</groupId>
<artifactId>lucene-highlighter</artifactId>
<version>7.4.0</version>
</dependency>
</dependencies>
1.2 创建测试类
2、往索引库中写入文档
2.1 基本流程
步骤:
2.1.1 创建索引库对象,指定索引库的位置
2.1.2 创建IndexWriterConfig对象并制定分词对象
2.1.3 创建一个IndexWriter对象
1)指定索引库的位置
2)指定一个IndexWriterConfig对象。
2.1.4 创建document对象。
2.1.5 创建field对象,将field添加到document对象中。
2.1.6 使用indexwriter对象将document对象写入索引库中。
2.1.7 关闭indexwriter对象。
2.2 代码实现
import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.document.*;
import org.apache.lucene.index.*;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.ScoreDoc;
import org.apache.lucene.search.TermQuery;
import org.apache.lucene.search.TopDocs;
import org.apache.lucene.store.FSDirectory;
import org.junit.Test; import java.io.File;
import java.io.IOException;
import java.nio.file.Path; /**
* @author PC-Black
* @version v1.0
* @date 2019/7/19 10:00
* @description TODO
**/
public class LuceneTest { @Test
public void addOneDoc() throws IOException {
// 1 创建索引库对象,指定索引库的位置
//1.1 创建索引库位置
Path path = new File("D:\\lucene").toPath();
//1.2 创建索引库对象,关联索引库位置
FSDirectory directory = FSDirectory.open(path);
// 2 创建IndexWriterConfig对象并指定分词器对象
//2.1 创建分词器对象用于指定分词规则
StandardAnalyzer standardAnalyzer = new StandardAnalyzer();//标准分词器,分词规则:单字分词
//2.2 创建写出器配置对象,关联分词器对象
IndexWriterConfig indexWriterConfig = new IndexWriterConfig(standardAnalyzer);
// 3 创建一个IndexWriter对象 &指定索引库的位置&指定一个IndexWriterConfig对象。
IndexWriter indexWriter = new IndexWriter(directory, indexWriterConfig);
// 4 创建document对象。
Document document = new Document();
// 5 创建field对象,将field添加到document对象中。
// 5.1 创建field对象
StringField docIdField = new StringField("docId", "1", Field.Store.YES);
TextField titleField = new TextField("title", "我的祖国", Field.Store.YES);
TextField contentField = new TextField("content", "我的祖国是一个伟大的国家", Field.Store.YES);
StringField scoreField = new StringField("score", "100", Field.Store.YES);
//5.1 将field添加到document对象中。
document.add(docIdField);
document.add(titleField);
document.add(contentField);
document.add(scoreField);
// 6 使用indexwriter对象将document对象写入索引库中。
indexWriter.addDocument(document);
// 7 关闭indexwriter对象。
indexWriter.close(); }
}
2.3 运行addOneDoc()方法
2.4 查看索引库生成的位置
2.5 使用Luke工具查看索引
注意:我们使用的luke版本是luke-7.4.0,跟Lucene的版本是对应的。所以可以打开7.4.0版本的Lucene创建的索引库。并且此版本的luke是jdk9编译的,所以要想运行此工具还需要jdk9才可以
3、在索引库中查询文档
3.1 查询流程
步骤:
3.1.1 创建索引库对象,指定索引库位置。
3.1.2 创建索引读取对象(IndexReader),指定索引库对象。
3.1.3 创建索引查询器对象(IndexSearcher),指定索引读取对象。
3.1.4 创建TermQuery对象,指定查询的域和查询的关键词。
3.1.5 使用索引查询器对象执行查询方法。
3.1.6 返回查询结果。遍历查询结果并输出。
3.1.7 关闭IndexReader对象。
3.2 代码实现
@Test
public void queryDoc() throws IOException {
// 1 创建索引库对象&指定索引库位置。
FSDirectory fsDirectory = FSDirectory.open(new File("D:\\lucene").toPath());
// 2 创建索引读取对象(IndexReader),指定索引库对象。
// DirectoryReader open = DirectoryReader.open(fsDirectory);
//2.1 使用子类创建,父类引用
IndexReader indexReader = DirectoryReader.open(fsDirectory);
// 3 创建索引查询器对象(IndexSearcher),指定索引读取对象。
IndexSearcher indexSearcher = new IndexSearcher(indexReader);
// 4 创建分词查询对象(TermQuery),指定查询的域和查询的关键词。
TermQuery termQuery = new TermQuery(new Term("title", "我"));
// 5 使用索引查询器对象执行查询方法。 参数一:查询条件 参数二:搜索的记录条数
TopDocs topDocs = indexSearcher.search(termQuery, 10);
// 6 返回查询结果。遍历查询结果并输出。
//6.1 获取查询到的结果
ScoreDoc[] scoreDocs = topDocs.scoreDocs;
//6.2 遍历查询结果
for (ScoreDoc scoreDoc : scoreDocs) {
//6.3 获取文档id,即docId
int docId = scoreDoc.doc;
//6.4 使用indexSearcher对象,根据docId获取document对象
Document document = indexSearcher.doc(docId);
//6.5 获取每个字段的值
if (null != document) {
String title = document.get("title");
String content = document.get("content");
String score = document.get("score");
System.out.println("docId=" + docId);
System.out.println("title=" + title);
System.out.println("content=" + content);
System.out.println("score=" + score);
} }
// 7 关闭IndexReader对象。
indexReader.close();
}
3.3 运行queryDoc方法
查看控制台,我们发现没有查到数据。
因为创建索引库写入文档时,我们使用的是标准的分词规则:即按照单字分词的。而我们查询的时候,查询的字段是title,查询的关键词是“我的”。title中并没有这个分词,所以找不到。
将关键词修改成“我”,再执行查询下:
Lucene02--入门程序的更多相关文章
- mybatis入门_mybatis基本原理以及入门程序
一.传统jdbc存在的问题 1.创建数据库的连接存在大量的硬编码, 2.执行statement时存在硬编码. 3.频繁的开启和关闭数据库连接,会严重影响数据库的性能,浪费数据库的资源. 4.存在大量的 ...
- 1.struts2原理和入门程序
Struts2是一个MVC的Web应用框架,是在Struts1和WebWork发展起来的,以WebWork为核心,采取拦截器机制来处理用户请求. 原理图: 分析步骤: 1.用户发送一个请求 2.请求的 ...
- springMVC2 1入门程序
1入门程序 .1需求 实现商品列表查询 .2需要的jar包 使用spring3.2.0(带springwebmvc模块) .1前端控制器 在web.xml中配置: <?xml version=& ...
- struts2入门程序
struts2入门程序 1.示例 搭建编程环境就先不说了,这里假设已经搭建好了编程环境,并且下好了strut2的jar包,接下来程序. 1.1 新建web项目 点击File->New->D ...
- Spring+SpringMVC+MyBatis深入学习及搭建(十二)——SpringMVC入门程序(一)
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6999743.html 前面讲到:Spring+SpringMVC+MyBatis深入学习及搭建(十一)——S ...
- springmvc(一) springmvc框架原理分析和简单入门程序
springmvc这个框架真的非常简单,感觉比struts2还更简单,好好沉淀下来学习~ --WH 一.什么是springmvc? 我们知道三层架构的思想,并且如果你知道ssh的话,就会更加透彻的理解 ...
- python web入门程序
python2.x web入门程序 #!/usr/bin/python # -*- coding: UTF-8 -*- # 只在python2.x 有效 import os #Python的标准库中的 ...
- Maven01——简介、安装配置、入门程序、项目构建和依赖管理
1 Maven的简介 1.1 什么是maven 是apache下的一个开源项目,是纯java开发,并且只是用来管理java项目的 Svn eclipse maven量级 1.2 Maven好处 同 ...
- ssm整合快速入门程序(一)
整合基础说明 spring 是一个开放源代码的设计层面框架,他解决的是业务逻辑层和其他各层的松耦合问题,因此它将面向接口的编程思想贯穿整个系统应用.Spring是于2003 年兴起的一个轻量级的Jav ...
- Mybatis入门程序
作为一个java的学习者,我相信JDBC是大家最早接触也是入门级别的数据库连接方式,所以我们先来回忆一下JDBC作为一种用于执行SQL语句的Java API是如何工作的.下面的一段代码就是最基本的JD ...
随机推荐
- C#高性能大容量SOCKET并发(十):SocketAsyncEventArgs线程模型
原文:C#高性能大容量SOCKET并发(十):SocketAsyncEventArgs线程模型 线程模型 SocketAsyncEventArgs编程模式不支持设置同时工作线程个数,使用的NET的IO ...
- [机器学习]Bagging and Boosting
Bagging 和 Boosting 都是一种将几个弱分类器(可以理解为分类或者回归能力不好的分类器)按照一定规则组合在一起从而变成一个强分类器.但二者的组合方式有所区别. 一.Bagging Bag ...
- Delphi编写系统服务:完成端口演示
在开发大量Socket并发服务器,完成端口加重叠I/O是迄今为止最好的一种解决方案,下面是简单的介绍: “完成端口”模型是迄今为止最为复杂的一种I/O模型,特别适合需要同时管理为数众多的套接字,采 ...
- WCF研究-前篇
前篇 1.从SOA说起 2.什么是WCF 3.WCF通信模型 4.Endpoint与ABC以及元数据 1.SOA (Service Oriented Architecture) Ø 一种组件架 ...
- 实现js与Qt程序的交互(使用QtWebkit)
在QtWebkit的javascript里访问QObject的最关键的关键就是下面这个方法: void QWebFrame::addToJavaScriptWindowObject ( const Q ...
- libevent for qt的讨论
一直对Qt官方的QtNetwork模块抱有遗憾,Qt自带的网络模块用的是select模型,无法支持高并发的服务器开发.最近在网上看到有个libevent for qt的东西,它直接替换了Qt的sele ...
- 腾讯云直播录制遇到的bug
1.录制方式应用: 初始化方法 [[TXUGCRecordshareInstance] startCameraCustom:param preview:_showPlayerView]; ID ...
- 使用Nodejs实现实时推送MySQL数据库最新信息到客户端
下面我们要做的就是把MySQL这边一张表数据的更新实时的推送到客户端,比如MySQL这边表的数据abc变成123了,那使用程序就会把最新的123推送到每一个连接到服务器的客户端.如果服务器的连接的客户 ...
- 3013C语言_输入输出
第三章 输入输出 3.1输入输出概念及其实现 (1)数据从计算机内部向外部输出设备(如显示器.打印机等)输送的操作称为 “输出”,数据从计算机外部向输入设备(如键盘.鼠标.扫描仪等)送入的操作称为 “ ...
- 重定向Redirect 的知识
今天下班的时候看到了一些重定向的基础知识,也算开了眼界.以前也经常使用301和302,但从来没有使用过和了解过其他的3XX的状态码,发现原来里面涉及的知识和解决的问题的还不少. 重定向的流程 浏览器首 ...