я создаю поисковый индекс, который содержит специальные имена - содержащие! и ? и & и + и ... Я должен выполнить следующие поиски по-разному:
мне вас
я + ты
Но что бы я ни делал (пытался с помощью queryparser экранировать перед индексированием, сбегал вручную, пробовал разные индексаторы ...) - если я проверяю индекс поиска с помощью Люка, они не отображаются (появляются вопросительные знаки, @ -символы и тому подобное. )
Логика заключается в том, что я выполняю частичный поиск действующего предложения (а поля не такие большие), поэтому я разделил его на «m», «me», «+», «y» и «yo» и « you ", а затем проиндексировать его (в этом случае это будет намного быстрее, чем поиск по запросу с подстановочными знаками (и размер индекса не является большой проблемой).
Так что мне нужно было бы также вставить эти специальные символы подстановки в индекс.
Это мой код:
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using Lucene.Net.Analysis;
using Lucene.Net.Util;
namespace AnalyzerSpike
{
public class CustomAnalyzer : Analyzer
{
public override TokenStream TokenStream(string fieldName, TextReader reader)
{
return new ASCIIFoldingFilter(new LowerCaseFilter(new CustomCharTokenizer(reader)));
}
}
public class CustomCharTokenizer : CharTokenizer
{
public CustomCharTokenizer(TextReader input) : base(input)
{
}
public CustomCharTokenizer(AttributeSource source, TextReader input) : base(source, input)
{
}
public CustomCharTokenizer(AttributeFactory factory, TextReader input) : base(factory, input)
{
}
protected override bool IsTokenChar(char c)
{
return c != ' ';
}
}
}
Код для создания индекса:
private void InitIndex(string path, Analyzer analyzer)
{
var writer = new IndexWriter(path, analyzer, true);
//some multiline textbox that contains one item per line:
var all = new List<string>(txtAllAvailable.Text.Replace("\r","").Split('\n'));
foreach (var item in all)
{
writer.AddDocument(GetDocument(item));
}
writer.Optimize();
writer.Close();
}
private static Document GetDocument(string name)
{
var doc = new Document();
doc.Add(new Field(
"name",
DeNormalizeName(name),
Field.Store.YES,
Field.Index.ANALYZED));
doc.Add(new Field(
"raw_name",
name,
Field.Store.YES,
Field.Index.NOT_ANALYZED));
return doc;
}
(Код с Lucene.net в версии 1.9.x (EDIT: извините - был 2.9.x), но совместим с Lucene из Java)
Спасибо