web-dev-qa-db-ja.com

Windows上のGeoDjango:設定でGDAL_LIBRARY_PATHを設定してみてください

私は前にこれを十数回やったことがありますが、今回は何かがうまくいきません。

ドキュメントに従って:

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依存関係のバージョン管理の問題ですか?どうしたらいいのか途方に暮れていますが、それは私にとって緊急事態のようなものです。

9
Adam Starrh

問題は DjangoとGDALの間のバージョンの不一致 です。Djangoは正しいファイル名を検索していません(_gdal202.dll_(私の場合)。

これを修正するには、26行目の次のファイルにstr('gdal202')を追加する必要がありました。

_(Python Root)\Lib\site-packages\Django\contrib\gis\gdal\libgdal.py_

仮想環境で作業している場合、_Python Root_は実際にはどこにあるかに注意してください:_Users\YourName\Envs\project_

この問題が再発する場合は、_C:\OSGeo4W\bin_ディレクトリを調べて、どの_gdalxxx.dll_ Djangoで検索する必要があるか)を確認できます。

さらに、PythonおよびOSGeo4Winの32ビットバージョンを使用していることを確認してください。それ以外の場合は、同じエラーが発生する可能性があります。

12
Adam Starrh

追加

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

Django設定が私のために働いた

5

以前のコメントに加えて。 [WinError 127]が指定されている可能性があります指定されたプロシージャが見つかりませんでした。

これは、システムに複数のsqlite3.dllがあるために表示されます。パスが最初にヒットした場合、gdal202の競合が発生します。

作業ディレクトリの変更も追加することで、adam starrhの回答を拡張できます。

#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)
3
Mike - kentivo

Djangoチュートリアルを使用し、OSGeo4Wを介してGDALをインストールする場合、Windows環境を変更するときに、適切なPythonおよびOSGeo4Wバージョンを定義していることを確認してください。

たとえば、64ビットOSGeo4Wをインストールする場合、環境パスを設定する必要があります。

set OSGEO4W_ROOT=C:\OSGeo4W64

Python 3.5.2の場合:

set PYTHON_ROOT=C:\Python36

Python virtualenvへのインストールをシステムPythonと混同しないように注意してください。

インストールのみDjango after環境を適切に変更しました。

2
tmpbtz

私にとって、この問題はWindowsでパスをosgeo pythonパッケージに環境変数(C:\ Python36\Lib\site -packages\osgeo)。これを実行した後、Djangoがgdal202.dllファイル。

1
Hakim

解決:

  1. GDALをpipからインストールします:_pip install GDAL_、動作しない場合はホイールからインストールします: https://www.lfd.uci.edu/~gohlke/pythonlibs/#gdal
  2. a)仮想環境を使用する場合は、このコードをsettings.pyに追加するだけです:_os.environ["PATH"] += os.pathsep + BASE_DIR + '\\venv\\Lib\\site-packages\\osgeo'_

    b)または、次のコードを追加します。

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

移行を行うと、次のような問題が発生します ここに画像の説明を入力してください

多分dll(gdal202.dll)libは動作しません。 GDALライブラリ全体をGDAL-whl-packageに置き換えます 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フォルダーを1か所に抽出(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%"

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」に名前変更することを忘れないでください

0