【发布时间】:2015-07-21 11:51:10
【问题描述】:
我正在学习如何使用 Geo Django。当用户注册时,我保存纬度和经度信息,如下所示:
from django.contrib.gis.db import models
from django.contrib.gis.geos import Point
class GeoModel(models.Model):
"""
Abstract model to provide GEO fields.
"""
latitude = models.FloatField(blank=True, null=True, verbose_name='Latitude')
longitude = models.FloatField(blank=True, null=True, verbose_name='Longitude')
location = models.PointField(blank=True, null=True)
class Meta:
abstract = True
def save(self, *args, **kwargs):
if self.latitude and self.longitude:
self.location = Point(float(self.latitude), float(self.longitude))
super(GeoModel, self).save(*args, **kwargs)
接下来我想添加一个名为 city 的新字段,其中**我想根据给出的经纬度详细信息存储城市“名称”,即伦敦。
我查看了django-cities,其中保存了 Geo Name 中的城市数据库,但这似乎有点矫枉过正,而且不兼容 Python 3,所以对我来说不行。我见过一个名为geopy 的包,但这似乎完全取代了 Geo Django 并使用了带有限制的 Google API。
我想坚持使用 Geo Django 并以某种方式查找基于 long 和 lat 的城市名称,那么我有什么选择?即..
- 想办法安装http://www.geonames.org/data django-cities 不适用于 Python 3 和 Django 1.8.x
- 不知何故使用 Geo Django 使用数据进行此查找? (不确定该怎么做)
以上是解决这个问题的正确方法吗?如果是这样,我如何将数据导入我的数据库,然后使用 Geo Django 对其进行查找以查找城市名称?
【问题讨论】: