Geo Django 从纬度和经度获取城市

问题描述 投票:0回答:2

我正在学习如何使用 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 并以某种方式进行查找以根据经度和纬度找出城市名称,那么我的选择是什么?即..

  1. 找到安装方法 http://www.geonames.org/ data django-cities 不适用于 Python 3 和 Django 1.8.x
  2. 以某种方式使用 Geo Django 使用数据进行此查找? (不确定如何执行此操作)

以上是解决此问题的正确方法吗?如果是这样,我如何将数据放入数据库,然后使用 Geo Django 进行查找以查找城市名称?

python django geodjango
2个回答
10
投票

您有多种解决方案可以做到这一点:

  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

根据您感兴趣的国家/地区,您可能会找到城市几何形状来填充 OpenData 中的城市表(例如 http://www.gadm.org/country(未经测试,但似乎建议开放 shapefile))

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

0
投票

遵循 @stellasia 解决方案,这是一个 Jupyter Notebook 示例,展示了如何填充此类几何字段。

该解决方案太过分了,我强烈建议仅针对所需的地理实体进行过滤,或者仅针对国家和地区运行。

© www.soinside.com 2019 - 2024. All rights reserved.