haystack autocomplete引发奇怪的错误

时间:2017-02-21 18:42:03

标签: django solr autocomplete django-haystack

好的,所以我试图在我的django项目中使用haystack和solr在搜索字段上实现自动完成,但我一直在运行'没有初始值的'reduce()空序列'错误。我不确定当我重建索引时这是怎么回事我看到它在我的数据库中索引超过200个三元组。

我不确定我是否正确理解了SQS模块,我希望有人能指出我正确的方向。

我想在搜索时使用Triple模型字段作为自动填充建议。

我的模型,索引和视图:

MODEL:

# Create your models here.
class Triple(models.Model):
    studies = models.ForeignKey(Studies, on_delete=models.CASCADE)

    Subject = models.CharField(max_length=550, default='')
    Predicate = models.CharField(max_length=550, default='')
    Object = models.CharField(max_length=550, default='')

    updated = models.DateTimeField(auto_now=True, auto_now_add=False)
    timestamp = models.DateTimeField(auto_now=False, auto_now_add=True)

    def __unicode__(self):
        return '%s %s %s' % (self.Subject, self.Predicate, self.Object)

    def __str__(self):
        return '%s %s %s' % (self.Subject, self.Predicate, self.Object)

    def get_absolute_url(self):
        return reverse("queries:detail", kwargs={"id": self.id})


INDEX:

class TripleIndex(indexes.SearchIndex, indexes.Indexable):
    text = indexes.CharField(document=True, use_template=True)
    link = indexes.CharField(model_attr='studies')

    content_auto = indexes.EdgeNgramField(model_attr='Object')


    def get_model(self):
        return Triple

    def index_queryset(self, using=None):
        """Used when the entire index for model is updated."""
        return self.get_model().objects.all()

我认为问题似乎源于这一行:

sqs = SearchQuerySet().autocomplete(content_auto=request.GET.get('q', ''))[:5]

1 个答案:

答案 0 :(得分:0)

autocomplete有哪些输入可以解决此错误?

我认为可能传递空字符串可能会触发错误。