GeoDjango в Windows: попробуйте установить GDAL_LIBRARY_PATH в настройках.

Я делал это уже десяток раз, но на этот раз что-то не работает..

Следуя документам:

https://docs.djangoproject.com/en/1.11/ref/contrib/gis/install/#windows

Я пытаюсь настроить GeoDjango на компьютере с Windows (это виртуальный Windows 10, настроенный на paperspace.com). Кажется, есть проблема с моими настройками PATH, но я не могу понять, что это такое. Я выполнил команды, выделенные в инструкции. Я проверил свои переменные PATH, и все кажется в порядке. Я пытался указать им как 32-битную, так и 64-битную версии OSGeo4Win. Несмотря на это, я каждый раз получаю следующий вывод:

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? Я в недоумении, что делать, но для меня это своего рода чрезвычайная ситуация.


person Adam Starrh    schedule 23.05.2017    source источник


Ответы (9)


Проблема оказалась в несоответствии версий между 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. В противном случае вы можете увидеть тот же сбой.

person Adam Starrh    schedule 26.05.2017
comment
Комментарий, чтобы добавить, что 1.11.13 записывает только до версий ('gdal201.dll'), поэтому я думаю, что это исправление требуется для всех версий 1.11. - person Adam Starrh; 11.05.2018
comment
Сейчас это требуется и для Django 2.2.6. Требуемое имя файла на сегодняшний день gdal204.dll. - person Adam Starrh; 30.10.2019

Добавление

GDAL_LIBRARY_PATH = r'C:\OSGeo4W64\bin\gdal202'

чтобы настройки django сработали для меня

person Saltanat Alikhanova    schedule 23.02.2018
comment
какие настройки django, например, какой файл? - person ziggy; 28.02.2018
comment
в моем проекте он находится в папке_проекта/config/settings/base.py. Подробнее о настройках django docs.djangoproject.com/en/2.0/ref/settings docs.djangoproject.com/en/2.0/topics/settings - person Saltanat Alikhanova; 14.03.2018
comment
Имейте в виду, что этот подход будет разрушительным, если вы переключаетесь между средами разработки Windows и Mac или Linux. - person Adam Starrh; 12.04.2018

В дополнение к предыдущим комментариям. Возможно, у вас возникла ошибка [WinError 127]. Указанная процедура не найдена.

Это происходит из-за наличия в вашей системе нескольких sqlite3.dll. Если путь попадает к ним первым, возникает конфликт для gdal202.

Вы можете расширить ответы Адама Старра, добавив также смену рабочего каталога.

#Set working directory to actual working directoy of gdal
#This is required to prevent any conflicts with older SQLITE versions, 
#f.e. in python path  
#Prevents error in GDAL 202
#BASE_WORKINGDIRECTORY to change it back later if you need to
BASE_WORKDIRECTORY = os.getcwd()
os.chdir(os.path.dirname(lib_path))

# This loads the GDAL/OGR C library
lgdal = CDLL(lib_path)
person Mike - kentivo    schedule 11.04.2018
comment
это в Lib\site-packages\django\contrib\gis\gdal\libgdal.py - person danleyb2; 03.06.2018
comment
Я тоже получаю ошибку [WinError 127], но предложенный подход, к сожалению, не решает проблему. При вызове makemigrations из PyCharm я получаю сообщение об ошибке. Точка входа в процедуру sqlite3_column_origin_name не может быть расположена в библиотеке динамической компоновки C:\OSGeo4W64\bin\gdal202.DLL. В сети не нашел решения по этому поводу - person silentsurfer; 28.11.2018
comment
Обновление: мне пришлось сделать это тоже после установки GDAL через pip из: lfd.uci .edu/~gohlke/pythonlibs/#gdal Вы спасаете жизнь!! - person silentsurfer; 29.11.2018

Если вы используете учебник Django и устанавливаете GDAL через OSGeo4W, при изменении среды Windows убедитесь, что вы определили правильные версии Python и OSGeo4W.

Например, при установке 64-битной OSGeo4W путь среды должен быть установлен:

set OSGEO4W_ROOT=C:\OSGeo4W64

и для Python 3.5.2:

set PYTHON_ROOT=C:\Python36

Убедитесь, что вы не путаете установку Python в виртуальной среде с системным Python.

Устанавливайте Django только после корректного изменения среды.

person tmpbtz    schedule 31.05.2018
comment
Не могли бы вы пояснить, что вы имеете в виду, когда говорите, что не путаете установку Python в виртуальной среде с системным Python? - person silentsurfer; 27.11.2018
comment
убедитесь, что назначение среды пути отражает версию Python, которую вы будете использовать в активной виртуальной среде. - person tmpbtz; 29.11.2018

У меня такая же ошибка.

django.core.exceptions.ImproperlyConfigured: Could not find the GDAL library (tried "gdal204", "gdal203", "gdal202", "gdal201", "gdal20"). Is GDAL installed? If it is, try setting GDAL_LIBRARY_PATH in your settings.

Сначала установите OSGeo4W , а затем добавьте следующий код в файл settings.py.

import os
if os.name == 'nt':
    import platform
    OSGEO4W = r"C:\OSGeo4W"
    if '64' in platform.architecture()[0]:
        OSGEO4W += "64"
    assert os.path.isdir(OSGEO4W), "Directory does not exist: " + OSGEO4W
    os.environ['OSGEO4W_ROOT'] = OSGEO4W
    os.environ['GDAL_DATA'] = OSGEO4W + r"\share\gdal"
    os.environ['PROJ_LIB'] = OSGEO4W + r"\share\proj"
    os.environ['PATH'] = OSGEO4W + r"\bin;" + os.environ['PATH']

и запустите python manage.py check, если ошибка по-прежнему возникает, перейдите в C:\OSGeo4W64 или C:\OSGeo4W. Там вы можете найти gdalxxx.dll. пожалуйста, переименуйте имя файла в «gdal202» или «gdal203» в сообщении об ошибке. Пожалуйста, запустите python manage.py check, это должно сработать.

person Developer 613    schedule 29.07.2020
comment
Я рад, что прокрутил до конца... Но я действительно не понимаю, почему это работает, а то, что выше, нет. Тем не менее, очень благодарен. Спасибо - person bluppfisk; 04.11.2020
comment
Оказывается, нужно добавить c:\osgeo4w64\bin к пути Windows. Но странно, что установка GDAL_LIBRARY_PATH в тот же файл не работает - person bluppfisk; 04.11.2020
comment
Это работает, потому что вы даете файлу GDAL имя, которое соответствует конкретным запросам имени файла, которые ищет Django. - person Adam Starrh; 25.11.2020

Для меня эта проблема была решена на Windows простым добавлением пути к пакету osgeo python в переменные среды (C:\Python36\Lib\site-packages\osgeo). Кажется, после этого django удалось найти файл gdal202.dll.

person Hakim    schedule 13.04.2018

Решение:

  1. Установите GDAL из пункта: pip install GDAL, если не работает, установите его из колеса: https://www.lfd.uci.edu/~gohlke/pythonlibs/#gdal
  2. а) Если вы используете виртуальную среду, просто добавьте этот код в settings.py: os.environ["PATH"] += os.pathsep + BASE_DIR + '\\venv\\Lib\\site-packages\\osgeo'

    б) В противном случае добавьте этот код:

    from distutils.sysconfig import get_python_lib os.environ["PATH"] += os.pathsep + get_python_lib() + '\\osgeo'

person Дмитрий Винник    schedule 27.08.2018

При миграции возникает такая проблема: введите здесь описание изображения

Возможно, библиотека dll (gdal202.dll) не работает. поэтому мы можем заменить всю библиотеку GDAL пакетом GDAL-whl из https://download.lfd.uci.edu/pythonlibs/r5uhg2lo/GDAL-2.3.2-cp36-cp36m-win_amd64.whl загрузите этот пакет whl, переименуйте его в GDAL- 2.3.2-cp36-cp36m-win_amd64.whl.zip введите здесь описание изображения извлечь папку osgeo в одно место (D:\ProgramData\osgeo) и измените GDAL_DATA PROJ_LIB и путь к ее подпапке

что означает изменение среды Windows с

set OSGEO4W_ROOT=C:\OSGeo4W
set PYTHON_ROOT=C:\Python3X
set GDAL_DATA=%OSGEO4W_ROOT%\share\gdal
set PROJ_LIB=%OSGEO4W_ROOT%\share\proj
set PATH=%PATH%;%PYTHON_ROOT%;%OSGEO4W_ROOT%\bin
reg ADD "HKLM\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" /v Path /t REG_EXPAND_SZ /f /d "%PATH%"
reg ADD "HKLM\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" /v GDAL_DATA /t REG_EXPAND_SZ /f /d "%GDAL_DATA%"
reg ADD "HKLM\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" /v PROJ_LIB /t REG_EXPAND_SZ /f /d "%PROJ_LIB%"

to

set OSGEO4W_ROOT=D:\ProgramData\osgeo
set PYTHON_ROOT=C:\Python3X
set GDAL_DATA=%OSGEO4W_ROOT%\data\gdal
set PROJ_LIB=%OSGEO4W_ROOT%\data\proj
set PATH=%PATH%;%PYTHON_ROOT%;%OSGEO4W_ROOT%\bin
reg ADD "HKLM\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" /v Path /t REG_EXPAND_SZ /f /d "%PATH%"
reg ADD "HKLM\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" /v GDAL_DATA /t REG_EXPAND_SZ /f /d "%GDAL_DATA%"
reg ADD "HKLM\SYSTEM\CurrentControlSet\Control\Session Manager\Environment" /v PROJ_LIB /t REG_EXPAND_SZ /f /d "%PROJ_LIB%"

PS: не забудьте переименовать "D:\ProgramData\osgeo\gdal203.dll" в "D:\ProgramData\osgeo\gdal202.dll"

person 蒙古海军司令    schedule 10.12.2018

У меня была такая же проблема в Django в виртуальной среде. Что решило мою проблему:

  1. В settings.py добавьте путь к gdalxxx.dll, который пытается использовать ваше приложение, для меня это было

     GDAL_LIBRARY_PATH = r'C:\Users\<User>\Documents\<proj>\Lib\site-packages\osgeo\gdal301'
    

Это само по себе может решить вашу проблему, но Django все еще может жаловаться на отсутствие библиотеки GEOS, в этом случае:

  1. В settings.py добавьте путь к geos_c.dll, который пытается использовать ваше приложение, для меня это было:

    GEOS_LIBRARY_PATH = r'C:\Users\<User>\Documents\<proj>\Lib\site-packages\shapely\DLLs\geos_c'
    
person Ivan Kljun    schedule 25.11.2020
comment
Имейте в виду, что этот подход будет разрушительным, если вы переключаетесь между средами разработки Windows и Mac или Linux. - person Adam Starrh; 25.11.2020
comment
Установка пути в настройках тоже сработала для меня - person cgitosh; 08.04.2021