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

Pro*_*eus 12 python django geodjango

我正在学习如何使用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)
Run Code Online (Sandbox Code Playgroud)

接下来我想添加一个名为city**的新字段**我想存储城市"名称",即伦敦基于给出的长和纬度细节.

我已经看过django-cities从Geo Name保存城市数据库的位置,但这看起来有些过分而且不兼容Python 3所以不适合我.我见过一个名为geopy的软件包,但这似乎完全取代了Geo Django并使用了带有限制的Google API.

我想坚持使用Geo Django并以某种方式进行查找以找出基于long和lat的城市名称,那么我的选择是什么?即.

  1. 找到一种安装方式http://www.geonames.org/ data django-cities不适用于Python 3和Django 1.8.x.
  2. 不知何故使用Geo Django使用数据进行查找?(不确定要做到这一点)

接近这个是正确的方法吗?如果是这样,我如何将数据存入我的数据库,然后使用Geo Django查找城市名称?

ste*_*sia 8

你有几个解决方案来做到这一点:

  1. 创建另一个模型城市

    from django.contrib.gis.db import models
    class City(models.Model):
        name = models.CharField(max_lenght=255)
        geometry = models.MultiPolygonField()
    
        objects = models.GeoManager()
    
    Run Code Online (Sandbox Code Playgroud)

然后,您可以找到包含您所在位置的城市名称:

    geomodel = GeoModel(...)
    city = City.objects.get(geometry__contains=geomodel.location)
    city_name = city.name
Run Code Online (Sandbox Code Playgroud)

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

  1. 使用反向地理编码器.如果符合您的需求,Google可以提供此类服务或查看http://www.geonames.org/export/reverse-geocoding.html.