如果可能的话,我想将我的代码更改限制在schema.xml
其他配置文件中。我的代码中有以下代码schema.xml
:
<field name="id" type="string" indexed="true" stored="true" required="true" multiValued="false" />
<field name="title" type="text_general" indexed="true" stored="true"/>
<field name="fact" type="string" indexed="true" stored="true" required="true" multiValued="false" />
<field name="body" type="text_exact_fuzzy" indexed="true" stored="true"/>
<copyField source="title" dest="text"/>
<copyField source="body" dest="text"/>
我在后面定义了 text_exact_fuzzyschema.xml
如下:
<text_exact_fuzzy: field type for fuzzy matching -->
<fieldType name="text_exact_fuzzy" class="solr.TextField" omitNorms="false">
<analyzer type="index">
<tokenizer class="solr.StandardTokenizerFactory"/>
<filter class="solr.StandardFilterFactory"/>
<filter class="solr.LowerCaseFilterFactory"/>
<filter class="solr.EdgeNGramFilterFactory" minGramSize="2" maxGramSize="15"/>
</analyzer>
<analyzer type="query">
<tokenizer class="solr.StandardTokenizerFactory"/>
<filter class="solr.StandardFilterFactory"/>
<filter class="solr.LowerCaseFilterFactory"/>
<!--
<filter class="solr.PorterStemFilterFactory"/>
-->
<filter class="solr.PhoneticFilterFactory" encoder="DoubleMetaphone" inject="true"/>
</analyzer>
</fieldType>
当我在 Django 视图中进行查询时,我使用以下代码(它接受查询并将波浪符号(例如 ~0.8)附加到查询中每个单词的末尾):
fuzzy_clean_text = re.sub(r'\s', '~' + str(fuzzy_index) + ' ', clean_text + ' ')
#return fuzzy_clean_text
post_params = [('q', re.escape(json.dumps(fuzzy_clean_text))),
('wt','json'),
('fl', 'fact'),
# I've tried the query with and without the following parameter:
#('spellcheck.collate', 'true'),
]
result = urllib2.urlopen(solr_server_url, urllib.urlencode(post_params))
response = json.loads(result.read())
但是,无论我如何设置fuzzy_index
,查询都会返回相同的结果。此外,模糊搜索非常宽松,有时会将不相关的文本匹配到特定fact
的 s。是否有另一种方法,通过查询参数或修改schema.xml
文件来纠正问题?其他 stackoverflow 帖子建议ComplexPhraseQueryParser
,但我不想将 Java 添加到我的代码库中(无论如何它似乎很难理解)。