2

我希望能够使用 django-haystack 对模型进行全文搜索。该模型使用 PointField 来存储坐标。我想根据与点的距离过滤搜索结果。Haystack可以做到这一点吗?有一个更好的方法吗?

from django.contrib.gis.db import models


class Listing(models.Model):
    name = models.CharField(max_length=255)
    description = models.TextField()
    location = models.PointField()
4

1 回答 1

3

听起来您希望用户在文本搜索中输入地理信息,例如地址或邮政编码。我就是这样做的,虽然我不确定它是如何扩展的。我刚刚在 5 分钟前完成了这个。

您应该创建一个从 SearchForm 或其他选项之一子类化的自定义搜索表单(对我来说是 FacetedSearchForm)。覆盖搜索方法。

首先将搜索字符串变成一个点。http://code.google.com/p/geopy/wiki/GettingStarted

class MainSearchForm(FacetedSearchForm):

    def search(self):

        query = self.cleaned_data['q']
        g = geocoders.Google()
        place, (lat, lng) = g.geocode('%s' % query)
        pnt = fromstr('POINT(%s %s)' % (lng, lat), srid=4326)

然后获取搜索查询集,我使用了RelatedSearchQuerySet ,因为它允许您使用我按距离过滤的 load_all_queryset()。GeoDjango 距离查询是 GeoDjango 的救援。通过距离查询,您可以选择如何过滤距离小于、大于等以及距离本身,以您想要的任何单位。

        sqs = RelatedSearchQuerySet().load_all()
        sqs = sqs.load_all_queryset(Listing, 
                                    Listing.objects.filter(location__distance_lte=(pnt, D(mi=20))))
        return sqs

这应该是一个坚实的开始。希望这能为您指明正确的方向。

于 2011-09-10T08:29:25.007 回答