我以前做过十几次,但这次有些东西不工作了。
按照文档:
https://docs.djangoproject.com/en/1.11/ref/contrib/gis/install/#windows
我正在尝试在 Windows 机器上设置 GeoDjango(这是在 paperspace.com 上设置的虚拟 Windows 10)。我的 PATH 设置似乎有问题,但我无法弄清楚它是什么。我已经运行了说明中突出显示的命令。我检查了我的 PATH 变量,一切似乎都正常。我已经尝试将它们指向 OSGeo4Win 的 32 位和 64 位版本。无论如何,我每次都会得到以下输出:
C:\Python\lib\site-packages\floppyforms__init__.py:21: UserWarning: Unable to import floppyforms.gis, geometry widgets not available
"Unable to import floppyforms.gis, geometry widgets not available")
Traceback (most recent call last):
File "manage.py", line 10, in <module>
execute_from_command_line(sys.argv)
File "C:\Python\lib\site-packages\django\core\management__init__.py", line 363, in execute_from_command_line
utility.execute()
File "C:\Python\lib\site-packages\django\core\management__init__.py", line 337, in execute
django.setup()
File "C:\Python\lib\site-packages\django__init__.py", line 27, in setup
apps.populate(settings.INSTALLED_APPS)
File "C:\Python\lib\site-packages\django\apps\registry.py", line 108, in populate
app_config.import_models()
File "C:\Python\lib\site-packages\django\apps\config.py", line 202, in import_models
self.models_module = import_module(models_module_name)
File "C:\Python\lib\importlib__init__.py", line 126, in import_module
return _bootstrap._gcd_import(name[level:], package, level)
File "<frozen importlib._bootstrap>", line 978, in _gcd_import
File "<frozen importlib._bootstrap>", line 961, in _find_and_load
File "<frozen importlib._bootstrap>", line 950, in _find_and_load_unlocked
File "<frozen importlib._bootstrap>", line 655, in _load_unlocked
File "<frozen importlib._bootstrap_external>", line 678, in exec_module
File "<frozen importlib._bootstrap>", line 205, in _call_with_frames_removed
File "C:\Python\lib\site-packages\django\contrib\auth\models.py", line 4, in <module>
from django.contrib.auth.base_user import AbstractBaseUser, BaseUserManager
File "C:\Python\lib\site-packages\django\contrib\auth\base_user.py", line 52, in <module>
class AbstractBaseUser(models.Model):
File "C:\Python\lib\site-packages\django\db\models\base.py", line 124, in __new__
new_class.add_to_class('_meta', Options(meta, app_label))
File "C:\Python\lib\site-packages\django\db\models\base.py", line 330, in add_to_class
value.contribute_to_class(cls, name)
File "C:\Python\lib\site-packages\django\db\models\options.py", line 214, in contribute_to_class
self.db_table = truncate_name(self.db_table, connection.ops.max_name_length())
File "C:\Python\lib\site-packages\django\db__init__.py", line 33, in __getattr__
return getattr(connections[DEFAULT_DB_ALIAS], item)
File "C:\Python\lib\site-packages\django\db\utils.py", line 211, in __getitem__
backend = load_backend(db['ENGINE'])
File "C:\Python\lib\site-packages\django\db\utils.py", line 115, in load_backend
return import_module('%s.base' % backend_name)
File "C:\Python\lib\importlib__init__.py", line 126, in import_module
return _bootstrap._gcd_import(name[level:], package, level)
File "C:\Python\lib\site-packages\django\contrib\gis\db\backends\postgis\base.py", line 5, in <module>
from .features import DatabaseFeatures
File "C:\Python\lib\site-packages\django\contrib\gis\db\backends\postgis\features.py", line 1, in <module>
from django.contrib.gis.db.backends.base.features import BaseSpatialFeatures
File "C:\Python\lib\site-packages\django\contrib\gis\db\backends\base\features.py", line 4, in <module>
from django.contrib.gis.db.models import aggregates
File "C:\Python\lib\site-packages\django\contrib\gis\db\models__init__.py", line 3, in <module>
from django.contrib.gis.db.models.aggregates import * # NOQA
File "C:\Python\lib\site-packages\django\contrib\gis\db\models\aggregates.py", line 1, in <module>
from django.contrib.gis.db.models.fields import ExtentField
File "C:\Python\lib\site-packages\django\contrib\gis\db\models\fields.py", line 3, in <module>
from django.contrib.gis import forms, gdal
File "C:\Python\lib\site-packages\django\contrib\gis\forms__init__.py", line 3, in <module>
from .fields import ( # NOQA
File "C:\Python\lib\site-packages\django\contrib\gis\forms\fields.py", line 4, in <module>
from django.contrib.gis.geos import GEOSException, GEOSGeometry
File "C:\Python\lib\site-packages\django\contrib\gis\geos__init__.py", line 5, in <module>
from .collections import ( # NOQA
File "C:\Python\lib\site-packages\django\contrib\gis\geos\collections.py", line 11, in <module>
from django.contrib.gis.geos.geometry import GEOSGeometry, LinearGeometryMixin
File "C:\Python\lib\site-packages\django\contrib\gis\geos\geometry.py", line 11, in <module>
from django.contrib.gis import gdal
File "C:\Python\lib\site-packages\django\contrib\gis\gdal__init__.py", line 28, in <module>
from django.contrib.gis.gdal.datasource import DataSource
File "C:\Python\lib\site-packages\django\contrib\gis\gdal\datasource.py", line 39, in <module>
from django.contrib.gis.gdal.driver import Driver
File "C:\Python\lib\site-packages\django\contrib\gis\gdal\driver.py", line 5, in <module>
from django.contrib.gis.gdal.prototypes import ds as vcapi, raster as rcapi
File "C:\Python\lib\site-packages\django\contrib\gis\gdal\prototypes\ds.py", line 9, in <module>
from django.contrib.gis.gdal.libgdal import GDAL_VERSION, lgdal
File "C:\Python\lib\site-packages\django\contrib\gis\gdal\libgdal.py", line 44, in <module>
'GDAL_LIBRARY_PATH in your settings.' % '", "'.join(lib_names)
django.contrib.gis.gdal.error.GDALException: Could not find the GDAL library (tried "gdal111", "gdal110", "gdal19", "gdal18", "gdal17"). Try setting GDAL_LIBRARY_PATH in your settings.
有人有什么想法吗?
更新:我去商店买了一台新笔记本电脑,但我仍然遇到同样的问题。这可能是某些 GeoDjango 依赖项的版本控制问题吗?我不知所措,但这对我来说有点紧急。
原文由 Adam Starrh 发布,翻译遵循 CC BY-SA 4.0 许可协议
问题最终成为 Django 和 GDAL 之间的版本不匹配。 Django 没有搜索正确的文件名(在我的例子中是
gdal202.dll
)。修复它需要我将
str('gdal202')
添加到第 26 行的以下文件中:(Python Root)\Lib\site-packages\django\contrib\gis\gdal\libgdal.py
请注意,如果您在虚拟环境中工作,那么
Python Root
实际上会在任何地方,即:Users\YourName\Envs\project
如果这个问题再次出现,您可以查看您的
C:\OSGeo4W\bin
目录,找出哪个gdalxxx.dll
是 Django 需要搜索的。此外,请确保您使用 的是 32 位版本 的 Python 和 OSGeo4Win。否则,您可能会看到同样的失败。