cam*_*100 7 python django django-models whoosh django-haystack
我正在尝试在具有多对多字段的模型上运行搜索,并且我想使用此字段过滤搜索.
这是我目前的代码:
search_indexes.py
class ListingInex(indexes.SearchIndex, indexes.Indexable):
text = indexes.CharField(document=True, use_template=True)
business_name = indexes.CharField(model_attr='business_name')
category = indexes.MultiValueField(indexed=True, stored=True)
city = indexes.CharField(model_attr='city')
neighborhood= indexes.CharField(model_attr='neighborhood')
state = indexes.CharField(model_attr='state')
address = indexes.CharField(model_attr='address')
zip_code = indexes.CharField(model_attr='zip_code')
phone_number = indexes.CharField(model_attr='phone_number')
def get_model(self):
return listing
def index_queryset(self, using=None):
return self.get_model().objects.all()
def prepare_category(self, obj):
return [category.name for category in obj.category_set.all()]
Run Code Online (Sandbox Code Playgroud)
listing_text.txt
{{ object.business_name }}
{{ object.state }}
{{object.city}}
{{object.zip_code}}
{{object.phone_number}}
{{object.neighborhood}}
{% for category in obj.category.all %}
{{ category.name }}
{% endfor %}
Run Code Online (Sandbox Code Playgroud)
我正在尝试做一个简单的搜索:
search_results = SearchQuerySet().filter(category=query_text).filter
Run Code Online (Sandbox Code Playgroud)
它返回一个空列表.提前致谢.
读了你的代码我认为问题出在这里:
{% for category in obj.category.all %}
{{ category.name }}
{% endfor %}
Run Code Online (Sandbox Code Playgroud)
Category不是一个对象,是一个MultiValueField。也许如果你尝试这样的事情:
{% for category in object.category.all %}
{{ category.name }}
{% endfor %}
Run Code Online (Sandbox Code Playgroud)
object.category.all而不是 obj.category.all。我不确定解决方案是这样的,但我很确定错误可能在这三行中。