GeoJSON数据不包含有意义的数据GeoDjango

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

我正在使用vectorformats在我的地图上显示GeoDjango数据,跟随this resource。我在我的views.py文件中有这个:

def geojsonFeed(request):
    querySet = WorldBorder.objects.filter()
    djf = Django.Django(geodjango="mpoly", properties=['name', 'iso3'])
    geoj = GeoJSON.GeoJSON()
    s = geoj.encode(djf.decode(querySet))
    return HttpResponse(s)

但响应看起来像这样

["type", "features", "crs"]

任何人都可以帮我识别我的代码有什么问题吗?

更新:添加了WorldBorder模型

class WorldBorder(models.Model):
    # Regular Django fields corresponding to the attributes in the
    # world borders shapefile.
    name = models.CharField(max_length=50)
    area = models.IntegerField()
    pop2005 = models.IntegerField('Population 2005')
    fips = models.CharField('FIPS Code', max_length=2)
    iso2 = models.CharField('2 Digit ISO', max_length=2)
    iso3 = models.CharField('3 Digit ISO', max_length=3)
    un = models.IntegerField('United Nations Code')
    region = models.IntegerField('Region Code')
    subregion = models.IntegerField('Sub-Region Code')
    lon = models.FloatField()
    lat = models.FloatField()

    # GeoDjango-specific: a geometry field (MultiPolygonField)
    mpoly = models.MultiPolygonField()

    # Returns the string representation of the model.
    def __str__(self):
        return self.name

我正在使用Django 2.1.7

更新2:

>>> print(querySet)

<QuerySet [<WorldBorder: Antigua and Barbuda>, <WorldBorder: Algeria>, <WorldBorder: Azerbaijan>, <WorldBorder: Albania>, <WorldBorder: Anguilla>, <WorldBorder: Armenia>, <WorldBorder: Angola>, <WorldBorder: American Samoa>, <WorldBorder: Argentina>, <WorldBorder: Australia>, <WorldBorder: Andorra>, <WorldBorder: Gibraltar>, <WorldBorder: Bahrain>, <WorldBorder: Barbados>, <WorldBorder: Bermuda>, <WorldBorder: Bahamas>, <WorldBorder: Bangladesh>, <WorldBorder: Brunei Darussalam>, <WorldBorder: Canada>, <WorldBorder: Cambodia>, '...(remaining elements truncated)...']>
python django python-3.x geojson geodjango
1个回答
1
投票

编辑确认非空查询集后:

我发现了这个问题,它与vectorformats模块的核心代码有关。

具体来说,在GeoJSON.encode on this specific line内:

if to_string:
    result = json_dumps(list(result_data))

list()造成了这个问题。

让我们用一个最小的例子重新创建问题:

>>> import json
>>> test = {'a': 5, 'b': [1, 2, 3], 'c': {'e': 2, 'f': 5}}
>>> list(test)
['a', 'b', 'c']

在这里,我们看到与问题中的行为完全相同的行为。让我们进一步了解一下:

>>> json.dumps(list(test))
'["a", "b", "c"]'

但没有list()

>>> json.dumps(test)
'{"a": 5, "b": [1, 2, 3], "c": {"e": 2, "f": 5}}'

因此,围绕此问题有两种可能的解决方案:

  1. 更改vectorformat代码删除list()调用。
  2. encode调用to_string=False方法并自己“jsonify”生成的字典如下: import json def geojsonFeed(request): queryset = WorldBorder.objects.all() djf = Django.Django(geodjango="mpoly", properties=['name', 'iso3']) geoj = GeoJSON.GeoJSON() s = geoj.encode(djf.decode(queryset), to_string=False) return HttpResponse(json.dumps(s))

好吧,从您的模块快速研究,它似乎按预期工作,所以这不是原因。 看看GeoJSON.encode()方法:

def encode(self, features, to_string=True, **kwargs):
    """
    Encode a list of features to a JSON object or string.
    to_string determines whethr it should convert the result to
    a string or leave it as an object to be encoded later
    """
    results = []
    result_data = None
    for feature in features:
        data = self.encode_feature(feature)
        for key,value in data['properties'].items():
            if value and isinstance(value, str): 
                data['properties'][key] = str(value)
        results.append(data)

   result_data = {
                   'type':'FeatureCollection',
                   'features': results,
                   'crs': self.crs
                  }

   if to_string:
        result = json_dumps(list(result_data))
   else:
        result = result_data
   return result

result_data具有结构["type", "features", "crs"]并且它被转换为json列表,因为你有to_string参数默认为True

我可以想象你问题的唯一原因是querySet = WorldBorder.objects.filter()查询是空的。

顺便说一句,通过使用没有参数的filter(),你有一个类似于all()查询的结果。

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