5

在 Django 中,我一直在尝试获取一个搜索字段来对位置进行地理编码,并从我的数据库中吐出一个按距离排序的列表。到目前为止,一切正常,除了当我搜索谷歌返回多个结果表单的位置时,例如“安阿伯,MI”。我收到 ValueError “没有找到确切的地标!(找到 2。)”这是我的 views.py

from django.shortcuts import render_to_response
from models import CampSite
from geopy import geocoders
from django.contrib.gis.geos import *
from django.contrib.gis.measure import D
from campsites.forms import SearchForm
from django.http import HttpResponseRedirect


def results(request):
    query = request.GET['q']
    g = geocoders.Google(resource='maps')
    location, (lat, lon) = g.geocode(query) 
    pnt = fromstr("POINT(%s %s)" % (lon, lat))
    distance_from_point = {'mi':'2000'}
    results = CampSite.objects.filter(lonlat__distance_lte=(pnt,D(**distance_from_point))).distance(pnt).order_by('distance')
    return render_to_response('results.html',{'location': location, 'lat': lat, 'lon': lon, 'results':results})

我在网上找到的常见解决方案是更改

location, (lat, lon) = g.geocode(query)



location, (lat, lon) = g.geocode(query, exactly_one=False)

但是,这会产生新的 ValueError“字符串或 unicode 输入无法识别为 WKT EWKT 和 HEXEWKB”。

这是我在教程之外做的第一个 django 项目,所以谢谢你是外邦人。

4

1 回答 1

5

在 Python 中,解释器是你最好的朋友。

>>> g.geocode('ann arbor, MI', exactly_one=False)
[(u'Ann Arbor, MI, USA', (42.2808256, -83.743037799999996)),
 (u'Ann Arbor, MI, USA', (42.307649300000001, -83.8473015))]

如果您尝试使用您的代码片段,您会意识到当与 exact_one=False 一起使用时,该方法返回一个元组列表,而不是单个元组 - 因此您的代码需要相应地重构。

results = []
geocodes = g.geocode(query, exactly_one=False)
for geocode in geocodes:
    location, (lat, lon) = geocode
    pnt = fromstr("POINT(%s %s)" % (lon, lat))
    distance_from_point = {'mi':'2000'}
    results.append(
        CampSite.objects.filter(
             lonlat__distance_lte=(
                  pnt,
                  D(**distance_from_point)
             )
        ).distance(pnt).order_by('distance')
    )

以上内容未经测试,但在循环之后,您应该得到一个结果列表。然后你应该决定做什么:

  • 只显示第一个 ( geocodes[0], results[0])
  • 要求用户从列表中选择
  • zip(geocodes, results)显示所有结果(在模板中迭代)
于 2012-09-21T00:46:15.333 回答