3

我想我不能正确理解 django-haystack:

我有一个包含多个字段的数据模型,我希望搜索其中两个:

class UserProfile(models.Model):
    user = models.ForeignKey(User, unique=True, default=None)
    twitter_account = models.CharField(max_length=50, blank=False)

我的搜索索引设置:

class UserProfileIndex(SearchIndex):
    text = CharField(document=True, model_attr='user')
    twitter_account = CharField(model_attr='twitter_account')

    def get_queryset(self):
        """Used when the entire index for model is updated."""
        return UserProfile.objects.all()

但是当我执行搜索时,只搜索“用户名”字段;“twitter_account”被忽略。当我通过 dbshel​​l 选择 Searchresults 时,对象包含“user”和“twitter_account”的正确值,但结果页面显示“无结果”:

    {% if query %}
        <h3>Results</h3>

        {% for result in page.object_list %}
            <p>
               <a href="{{ result.object.get_absolute_url }}">{{ result.object.id }}</a>
            </p>
        {% empty %}
            <p>No results</p>
        {% endfor %}
    {% endif %}

有任何想法吗?

4

1 回答 1

9

我猜那是因为 haystack 使用文档字段进行通用搜索,除非您为其他字段(如 twitter_account 字段)定义特定搜索。

来自干草堆文档

每个 SearchIndex 都要求有一个(且只有一个)字段为 document=True。这向 Haystack 和搜索引擎指示哪个字段是在其中进行搜索的主要字段。

尝试按如下方式指定索引

class UserProfileIndex(SearchIndex):
    text = CharField(document=True, use_template=True)
    user = CharField(model_attr='user')
    twitter_account = CharField(model_attr='twitter_account')

并创建一个名为 search/indexes//userprofile_text.txt 的文件

其中将包含以下内容

{{ object.user.get_full_name }}
{{ object.twitter_account}}

现在,当您未指定索引过滤器时,haystack 将在此文件的内容中搜索(您可以在其中添加任何您想要的内容)。

于 2010-04-30T01:21:16.327 回答