我使用文本和数字索引文档。要创建索引,我使用
analyser = new SnowballAnalyzer(Version.LUCENE_30, "English");
我使用Snoschballanalyzer因为我需要形态学(表 - 表)。 当我在索引中搜索文本时 - 我找到了文本,但没有找到数值。我找到了一个解决方案 - Lucene - searching for a numeric value field ,但有必要为数值创建一个单独的字段。我现在不需要搜索一系列数值。我想找一个数值作为字符串。 示例 - 源文本:“他出生于1990年”。我需要根据要求“出生”和“1990”找到这个tesxt。
答案 0 :(得分:1)
你不应该做任何特别的事。
下面是一些代码,可以完成你想要实现的目标。
RAMDirectory dir = new RAMDirectory();
IndexWriter iw = new IndexWriter(dir, new SnowballAnalyzer(Lucene.Net.Util.Version.LUCENE_30,"English"), IndexWriter.MaxFieldLength.UNLIMITED);
Document d = new Document();
Field f = new Field("text", "", Field.Store.YES, Field.Index.ANALYZED);
d.Add(f);
f.SetValue("He was born 1990 years");
iw.AddDocument(d);
iw.Commit();
IndexReader reader = iw.GetReader();
IndexSearcher searcher = new IndexSearcher(reader);
QueryParser qp = new QueryParser(Lucene.Net.Util.Version.LUCENE_30, "text", new SnowballAnalyzer(Lucene.Net.Util.Version.LUCENE_30, "English"));
Query q = qp.Parse("+born +1990");
TopDocs td = searcher.Search(q, null, 25);
foreach (var sd in td.ScoreDocs)
{
Console.WriteLine(searcher.Doc(sd.Doc).GetField("text").StringValue);
}
searcher.Dispose();
reader.Dispose();
iw.Dispose();