lucene的基本使用

Lucene




lucene使用总结

1.创建索引库

1)确定索引路径   String path = "F:\\indexs";

2)关联索引路位置 FSDirectory directory = FSDirectory.(new File(path));     

3)创建IK分词器类型 Analyzer analyzer = new IKAnalyzer();

4)创建索引核心类配置 IndexWriterConfig indexWriterConfig = new IndexWriterConfig(Version.LUCENE_4_10_2, analyzer);

        5)创建分词器   indexWriter = new IndexWriter(directory, indexWriterConfig);

6)创建索引文章对象 Document doc = new Document();

7)添加索引内 doc.add(new StringField("id""p1010110", Store.)); doc.add(new TextField("title""Lucene经典教程", Store.));

8)添加索引库  indexWriter.addDocument(doc);

9)提交索引库 indexWriter.commit();

10)关闭资源 indexWriter.close();

2.搜索索引库

1)指定索引库位置 String path = "F:\\indexs";

2)读取索引库 DirectoryReader reader =  DirectoryReader.(FSDirectory.(new File(path)));
3)查询核心类 IndexSearcher indexSearcher = new IndexSearcher(reader);

4)制定查询内容        String qName="经典";

5)创建IK解析分词器 QueryParser qParser = new QueryParser("films"new IKAnalyzer());//films是查询字段名

6)解析查询内容 Query query = qParser.parse(qName);

      7)查询核心类查询 TopDocs topDocs= indexSearcher.search(query, 10);

  8)文档概要信息遍历for(ScoreDoc sdoc : scoreDocs){

             //获取文档Id

             int docId = sdoc.doc;

}

      

详细讲解:

1.关联索引路径2种: FSDirectory 文件磁盘路径、RAMDirectory 内存路径,依赖文件磁盘路径FSDirectory

2.分词器4中:IKAnalyzer(推荐,中英文使用,可以添加扩展词典和停用词典)、StandardAnalyzer(简单分单词和单个汉字)、CJKAnalyzer(两两拆分,不管词义)、SmartChineseAnalyzer(适合中文、英文不好并且不支持扩展)

3.Document的IndexableField 三个实现类 : LongField、StringField(不分词)、TextField(分词)、

自定义(需要存储,不需要索引的字段)

FieldType testType = newFieldType();

testType.setTokenized(false);//不分词

testType.setIndexed(true);//索引

testType.setStored(true);//存储

Field test = newField("title", "如何学习solr",testType);

document.add(test);

4.IndexWriter操作索引目录时,对目录进行加锁 write.lock,当两个writer同时操作索引目录的时候,会报错,解决工具类实现单例

5.QueryParser查询解析器 2中:QueryParser(只支持单域分词)、MultiFieldQueryParser(查询多个域)

6.Query查询 6中:termQuery(不分词查询)、FuzzyQuery(相似查询,最多2次变换)、NumericRangeQuery(范围查询)BooleanQuery(组合查询)

7.设置得分

8.设置高亮















Lucene.net 是一个开源的全文检索引擎库,它提供了一些基本的 API 来创建和维护索引,并且可以通过这些 API 来搜索索引中的文档。下面是一些使用 Lucene.net 的基本步骤: 1. 创建索引:使用 Lucene.net 的 API,可以创建一个空的索引。可以将文档添加到索引中,以便后续搜索。 2. 添加文档:使用 Lucene.net 的 API,可以将文档添加到索引中。可以为每个文档定义一个或多个字段。 3. 搜索索引:使用 Lucene.net 的 API,可以搜索索引中的文档。可以使用查询对象来指定搜索条件,例如搜索某个字段中包含特定关键字的文档。 4. 处理搜索结果:搜索结果是一组匹配查询条件的文档。可以使用 Lucene.net 的 API 来访问每个文档的字段,以便将搜索结果呈现给用户。 以下是一个简单的示例代码,可用于创建索引、添加文档和搜索索引: ``` // 创建索引 var indexDirectory = FSDirectory.Open(@"C:\myindex"); var analyzer = new StandardAnalyzer(LuceneVersion.LUCENE_48); var indexConfig = new IndexWriterConfig(LuceneVersion.LUCENE_48, analyzer); var writer = new IndexWriter(indexDirectory, indexConfig); // 添加文档 var doc = new Document(); doc.Add(new TextField("title", "Lucene.net tutorial", Field.Store.YES)); doc.Add(new TextField("content", "This is a tutorial on how to use Lucene.net for full text search.", Field.Store.YES)); writer.AddDocument(doc); // 搜索索引 var searcher = new IndexSearcher(writer.GetReader(true)); var queryParser = new QueryParser(LuceneVersion.LUCENE_48, "content", analyzer); var query = queryParser.Parse("full text search"); var topDocs = searcher.Search(query, 10); foreach (var scoreDoc in topDocs.ScoreDocs) { var doc = searcher.Doc(scoreDoc.Doc); Console.WriteLine(doc.Get("title")); } ``` 此示例创建一个名为“myindex”的索引目录,添加一个文档,然后搜索包含“full text search”关键字的文档。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值