`
hdxiong
  • 浏览: 372268 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Lucene 2.4 简单例子

阅读更多
package com.test;

import java.io.File;
import org.apache.lucene.analysis.Analyzer;
import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field;
import org.apache.lucene.index.IndexWriter;
import org.apache.lucene.queryParser.QueryParser;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.Query;
import org.apache.lucene.search.ScoreDoc;
import org.apache.lucene.search.Searcher;
import org.apache.lucene.store.Directory;
import org.apache.lucene.store.FSDirectory;


public class Lucene24 {

	public static void createIndex(Directory dir, Analyzer analyzer) {
		try {
    //参数依次:索引目录、分词工具、是否清空目录、字段值的最大长度(UNLImited即Interger.MaxValue)
			IndexWriter writer = new IndexWriter(dir, analyzer, true,
					IndexWriter.MaxFieldLength.UNLIMITED);
			Document doc = new Document();
			doc.add(new Field("name", "jack lucy", Field.Store.YES,
					Field.Index.ANALYZED));
			doc.add(new Field("country", "中国 美国", Field.Store.YES,
					Field.Index.ANALYZED));
			writer.addDocument(doc);

			doc = new Document();
			doc.add(new Field("name", "lucy lily", Field.Store.YES,
					Field.Index.ANALYZED));
			doc.add(new Field("country", "美国 日本", Field.Store.YES,
					Field.Index.ANALYZED));
			writer.addDocument(doc);

			doc = new Document();
			doc.add(new Field("name", "lily john", Field.Store.YES,
					Field.Index.ANALYZED));
			doc.add(new Field("country", "日本 韩国", Field.Store.YES,
					Field.Index.ANALYZED));
			writer.addDocument(doc);

			doc = new Document();
			doc.add(new Field("name", "john tom", Field.Store.YES,
					Field.Index.ANALYZED));
			doc.add(new Field("country", "韩国 法国", Field.Store.YES,
					Field.Index.ANALYZED));
			writer.addDocument(doc);

			doc = new Document();
			doc.add(new Field("name", "tom july", Field.Store.YES,
					Field.Index.ANALYZED));
			doc.add(new Field("country", "法国 德国", Field.Store.YES,
					Field.Index.ANALYZED));
			writer.addDocument(doc);

			doc = new Document();
			doc.add(new Field("name", "july kate", Field.Store.YES,
					Field.Index.ANALYZED));
			doc.add(new Field("country", "德国 英国", Field.Store.YES,
					Field.Index.ANALYZED));
			writer.addDocument(doc);
			// writer.optimize();
			writer.close();
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	public static void search(Directory dir, Analyzer analyzer) {
		try {
			Searcher searcher = new IndexSearcher(dir);
			Query query = new QueryParser("country", analyzer).parse("美国");
  //此处在2.0基础上有改动,此处必须传入一个返回条数,这里用searcher.maxDoc()表示返回所有条数。
			ScoreDoc[] docs = searcher.search(query, searcher.maxDoc()).scoreDocs;
			System.out.println(docs.length);;
			Document doc;
			for (int i = 0; i < docs.length; i++) {
				doc = searcher.doc(docs[i].doc);
				System.out.println(doc.get("country"));
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	public static void main(String[] args) {
		try {
			Analyzer analyzer = new StandardAnalyzer();
			FSDirectory dir = FSDirectory.getDirectory(new File("C:\\Lucene_index"));
			createIndex(dir, analyzer);
			search(dir, analyzer);
			dir.close();
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
}

分享到:
评论
5 楼 hdxiong 2009-07-22  
lawrenst 写道
假如我把content字段的内容放到文件中,把name域的内容当做文件名称,就搜不到了,这是为什么呢?

不明白你啥意思?
4 楼 lawrenst 2009-07-08  
假如我把content字段的内容放到文件中,把name域的内容当做文件名称,就搜不到了,这是为什么呢?
3 楼 chenhua_1984 2009-05-06  
非常好!收藏了!
2 楼 hdxiong 2009-03-23  
zpap 写道

这样贴出来也没有什么意义, 网上一搜一大半.. 应该加上注释跟解释吧.....

由于近段时间没有研究Lucene了,所以没来得及完善,谢谢你的提醒,我会抽时间补上去的。
1 楼 zpap 2009-03-17  
这样贴出来也没有什么意义, 网上一搜一大半..


应该加上注释跟解释吧.....

相关推荐

Global site tag (gtag.js) - Google Analytics