Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/django/20.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python Geo Django从经纬度获取城市_Python_Django_Geodjango - Fatal编程技术网

Python Geo Django从经纬度获取城市

Python Geo Django从经纬度获取城市,python,django,geodjango,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(b

我正在学习如何使用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
的新字段,其中**我想根据给出的long和lat详细信息存储城市“名称”,即伦敦

我已经看过了《django cities》(django cities)where is从Geo Name保存了一个城市数据库,但这似乎有些过分,而且与Python 3不兼容,所以我不想这样做。我见过一个名为Geo Django的包,但它似乎完全取代了Geo Django,并使用了带有限制的GoogleAPI

我想坚持使用Geo Django,然后根据long和lat查找城市名称,那么我有什么选择?i、 e

  • 找到一种方法来安装数据django cities 不适用于Python3和Django 1.8.x
  • 以某种方式使用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中找到城市几何图形来填充城市表(例如(未测试,但似乎建议使用开放形状文件))

  • 使用反向地理编码器。谷歌可以提供这样的服务,或者看看是否有东西能满足你的需求

  • geomodel.location
    这是什么类型的字段
    PointField
    ?是的,这是您在问题中定义的模型:)最后一个问题,因此城市模型中使用了
    MultiPolygonField
    。这是什么?看起来怎么样?我决定使用Geo Name,但它没有包含城市形状信息的字段MultiPolygonField,因此查找
    包含检查点是否位于多边形内。该形状似乎不存在于中。你对哪个国家感兴趣?试试看