Geo Django 从经纬度获取城市

Geo Django get cities from latitude and longitude

我正在学习如何使用 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 的新字段,其中 **我想存储城市 "name",即基于给定的经度和纬度详细信息的伦敦。

我看过 django-cities 哪里保存了来自 Geo Name 的城市数据库,但这似乎太过分了而且不兼容 Python 3,所以我不行。我见过一个名为 geopy 的包,但这似乎完全取代了 Geo Django 并使用了 Google API ,但它有限制。

我想坚持使用 Geo Django 并以某种方式查找以根据经度和纬度找出城市名称,那么我有什么选择?即..

  1. 想办法安装http://www.geonames.org/ data django-cities 不适用于 Python 3 和 Django 1。8.x
  2. 以某种方式使用 Geo Django 使用数据进行查找? (不确定该怎么做)

以上是正确的处理方法吗?如果是这样,我如何将数据导入我的数据库,然后使用 Geo Django 查找城市名称?

您有几种解决方案:

  1. 创建另一个模型城市

    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

根据您感兴趣的 country/region,您可能会在 OpenData 中找到填充城市 table 的城市几何图形(例如 http://www.gadm.org/country(未测试但似乎建议打开 shapefile ))

  1. 使用反向地理编码器。 Google 可以提供此类服务,或者查看 http://www.geonames.org/export/reverse-geocoding.html 是否有满足您需求的服务。