我正在学习如何使用 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 并以某种方式进行查找以根据经度和纬度找出城市名称,那么我的选择是什么?即..
以上是解决此问题的正确方法吗?如果是这样,我如何将数据放入数据库,然后使用 Geo Django 进行查找以查找城市名称?
您有多种解决方案可以做到这一点:
创建另一个模型城市
from django.contrib.gis.db import models
class City(models.Model):
name = models.CharField(max_lenght=255)
geometry = models.MultiPolygonField()
objects = models.GeoManager()
然后您可以通过以下方式找到包含您所在位置的城市名称:
geomodel = GeoModel(...)
city = City.objects.get(geometry__contains=geomodel.location)
city_name = city.name
根据您感兴趣的国家/地区,您可能会找到城市几何形状来填充 OpenData 中的城市表(例如 http://www.gadm.org/country(未经测试,但似乎建议开放 shapefile))
遵循 @stellasia 解决方案,这是一个 Jupyter Notebook 示例,展示了如何填充此类几何字段。
该解决方案太过分了,我强烈建议仅针对所需的地理实体进行过滤,或者仅针对国家和地区运行。