我有两个用于段落模型的字段,其中一个是 ManyToMany 字段。
class Tag(models.Model):
tag = models.CharField(max_length=500)
def __unicode__(self):
return self.tag
admin.site.register(Tag)
class Paragraph(models.Model):
article = models.ForeignKey(Article)
text = models.TextField()
tags = models.ManyToManyField(Tag)
def __unicode__(self):
return "Headline: " + self.article.headline + " Tags: " + ', '.join([t.tag for t in self.tags.all()])
admin.site.register(Paragraph)
我的 .txt 文件反映了与索引标签的多对多关系-
{{object.text}}
{% for tag in object.tags.all %}
{{tag.tag}}
{% endfor %}
然后,我的 views.py 使用 SQS 搜索所有标签(我想在包含文本字段之前先完成此操作)并检索这些标签。所以在这种情况下,查询是“政治”——
def politics(request):
paragraphs = []
sqs = SearchQuerySet().filter(tag="Politics")
paragraphs = [a.object for a in sqs[0:10]]
return render_to_response("search/home_politics.html",{"paragraphs":paragraphs},context_instance=RequestContext(request))
编辑:和我的 search_indexes.py
class ParagraphIndex(indexes.SearchIndex, indexes.Indexable):
text= indexes.CharField(document=True, use_template=True)
tags= indexes.CharField(model_attr='tags')
def get_model(self):
return Paragraph
def index_queryset(self):
return self.get_model().objects
def load_all_queryset(self):
# Pull all objects related to the Paragraph in search results.
return Paragraph.objects.all().select_related()
但是,即使一些段落具有“政治”标签,这也不会检索任何内容。我在这里遗漏了什么还是应该以另一种方式处理相关数据?我是 Haystack 的初学者,因此我们将不胜感激。提前致谢!