我喜欢使用haystack和woosh作为搜索引擎:
我的模型如下所示
class Person(models.Model):
personid = models.IntegerField(primary_key = True, db_column = 'PID')
firstname = models.CharField(max_length = 50, db_column = 'FIRSTNAME')
lastname = models.CharField(max_length = 50, db_column = 'LASTNAME')
class Meta:
db_table = '"TEST"."PERSON"'
managed = False
class TDoc(models.Model):
tdocid = models.IntegerField(primary_key = True, db_column = 'TDOCID')
person = models.ForeignKey(Person, db_column = 'PID')
content = models.TextField(db_column = 'CONTENT', blank = True)
filepath = models.TextField(db_column = 'FILEPATH', blank = True)
class Meta:
db_table = '"TEST"."TDOC"'
managed = False
search_index.py如下:
class TDocIndex(SearchIndex):
content = CharField(model_attr = 'content', document = True)
filepaht = CharField(model_attr = 'filepath')
person = CharField(model_attr = 'person')
def get_queryset(self):
return TDoc.objects.all()
def prepare_person(self, obj):
# Store a list of id's for filtering
return obj.person.lastname
site.register(TDoc, TDocIndex)
我的问题是我想进行多次搜索,例如
内容:xxx和人:SMITH
在干草堆上,它立即搜索所有这些,我无法进行特定的野外搜索。 我怀疑我的索引已损坏但是:
ix = open_dir("/testindex")
searcher = ix.searcher()
mparser = MultifieldParser(["content", "filepath", "person"], schema = ix.schema)
myquery = mparser.parse(content:xxx AND person:SMITH')
results = searcher.search(myquery)
for result in results:
print result
但它有效并返回正确的值。 我在教程中使用标准的haystack SearchView,search.html
(r'^search/', include('haystack.urls')),
答案 0 :(得分:4)
在索引中,您应该使用document=True
定义一个字段,这是haystack将搜索的文档。按照惯例,此字段名为text
。如果您打算对其值进行过滤或排序,则可以添加额外的字段。
执行搜索时在帐户中使用多个字段的方法是将文档定义为模板,并在文档字段中设置use_template
。您的索引如下:
class TDocIndex(SearchIndex):
text = CharField(document=True, use_template=True)
#if you plan to filter by person
personid = IntegerField(model_attr='person__id')
site.register(TDoc, TDocIndex)
你有一个search / indexes / tdoc_text.txt模板,如:
{{ object.content }}
{{ object.filepath }}
{{ object.person.lastname }}
请参阅this回答。