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 并以某种方式查找以根据经度和纬度找出城市名称,那么我有什么选择?即..
- 想办法安装http://www.geonames.org/ data django-cities
不适用于 Python 3 和 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
根据您感兴趣的 country/region,您可能会在 OpenData 中找到填充城市 table 的城市几何图形(例如 http://www.gadm.org/country(未测试但似乎建议打开 shapefile ))
- 使用反向地理编码器。 Google 可以提供此类服务,或者查看 http://www.geonames.org/export/reverse-geocoding.html 是否有满足您需求的服务。
我正在学习如何使用 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 并以某种方式查找以根据经度和纬度找出城市名称,那么我有什么选择?即..
- 想办法安装http://www.geonames.org/ data django-cities 不适用于 Python 3 和 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
根据您感兴趣的 country/region,您可能会在 OpenData 中找到填充城市 table 的城市几何图形(例如 http://www.gadm.org/country(未测试但似乎建议打开 shapefile ))
- 使用反向地理编码器。 Google 可以提供此类服务,或者查看 http://www.geonames.org/export/reverse-geocoding.html 是否有满足您需求的服务。