如何在Django-hays中解决相关模型中的过滤问题

2024-03-28 12:30:41 发布

您现在位置:Python中文网/ 问答频道 /正文

我有以下型号:

class Note(models.Model):
    user = ForeignKey(User)
    topic = CharField(max_length=20)

class Referral(models.Model):
    recipient = ForeignKey(User, related_name=referral_rcvd)
    giver = ForeignKey(User, related_name=referral_given)
    about = CharField(max_length=20)

以及search_indexes.py中的以下内容:

class NoteIndex(indexes.SearchIndex, indexes.Indexable):
    text = indexes.EdgeNgramField(document=True, use_template=True)
    topic = indexes.CharField(model_attr='topic')

我想在模板中看到的是:

Search for: <topic>

Results:
<ul>
<topic> <topic.user.username> <topic.user.referral_rcvd.filter(about=topic)
</ul>

在shell中工作更简单,这给了我想要的:

from haystack.query import SearchQuerySet as SQS
from models import *
s = SQS().models(Note).auto_query('topic_name')
[i.object.user.referral_rcvd.filter(about=i.object.topic).count() for i in s.all()]

但这在html模板中不起作用:

{% for result in object_list %}
   {{ result.object.user.referral_rcvd.filter(about=i.object.topic).count() }}
{% endfor %}

如果它在shell中工作,如何使它在模板中工作?谢谢!你知道吗


Tags: name模板fortopicobjectmodelsclassabout
1条回答
网友
1楼 · 发布于 2024-03-28 12:30:41

终于解决了!我所做的是使用prepare_FOO方法:

class NoteIndex(indexes.SearchIndex, indexes.Indexable):
    text = indexes.EdgeNgramField(document=True, use_template=True)
    topic = indexes.CharField(model_attr='topic')
    referral_count = indexes.IntegerField()

    def prepare_referral_count(self, obj):
        topic_name = Note.objects.get(pk=obj.pk).topic
        return obj.user.referral_rcvd.filter(about=topic_name).count()

然后我运行python manage.py update_index,并将以下内容放在我的模板中:

{% for result in object_list %}
   {{ result.referral }}
{% endfor %}

它不是result.object.referral,因为我们指的是索引中的某个东西。你知道吗

相关问题 更多 >