数据源:GDALException:未知错误代码:“-474873798”

DataSource: GDALException: Unknown error code: "-474873798"

我发现一件奇怪的事:

python manage.py shell之后,当我尝试使用GDAL接口使用django.contrib.gis.gdal.DataSource创建数据源时,它会先抛出错误,然后第二次尝试会成功。

from django.contrib.gis.gdal import DataSource
shp = 'someshapefile.shp'
ds = DataSource(shp)

这会引发一个GDALException: : Unknown error code: "-474873798"代码字符串不时变化。

但是当重试时:ds = DataSource(shp)数据源对象被实例化。

类似的问题也发生在ogrinspect命令和通过LayerMapping对象加载数据。

完整的错误提示如下:

from django.contrib.gis.gdal import DataSource
shp = 'province.shp'
DataSource(shp)
GDALException                             Traceback (most recent call last)
<ipython-input-3-c4eb8c662773> in <module>()
----> 1 DataSource(shp)

//anaconda/lib/python3.5/site-packages/django/contrib/gis/gdal/datasource.py in __init__(self, ds_input, ds_driver, write, encoding)
     62         self.encoding = encoding
     63 
---> 64         Driver.ensure_registered()
     65 
     66         if isinstance(ds_input, six.string_types):

//anaconda/lib/python3.5/site-packages/django/contrib/gis/gdal/driver.py in ensure_registered(cls)
     81         if not cls.driver_count():
     82             vcapi.register_all()
---> 83             rcapi.register_all()
     84 
     85     @classmethod

//anaconda/lib/python3.5/site-packages/django/contrib/gis/gdal/prototypes/errcheck.py in check_errcode(result, func, cargs, cpl)
    117     Check the error code returned (c_int).
    118     """
--> 119     check_err(result, cpl=cpl)
    120 
    121 

//anaconda/lib/python3.5/site-packages/django/contrib/gis/gdal/error.py in check_err(code, cpl)
     72         raise e(msg)
     73     else:
---> 74         raise GDALException('Unknown error code: "%s"' % code)

GDALException: Unknown error code: "-474873798"

DataSource(shp)
<django.contrib.gis.gdal.datasource.DataSource at 0x10cd6f4a8>

我可以在尝试导入 gpx 时复制此行为。调用 datasource = DataSource(gpx) 两次实例化 DataSource。

我希望临时解决方案是在我的应用程序中执行此操作:

try:
    datasource = DataSource(gpx)
except:
    datasource = DataSource(gpx)

filed a ticket 为 Django。

因此,我的问题现已解决。参见 ticket comment